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= Supports the Pentium® Pro Processors = PCI Bus Interface 

at Bus Frequencies Up To 66 Mhz — PCI Rev. 2.1, 5V Interface Compliant 

— Supports 32-Bit Addressing — Greater than 100 MBps Data 

— Optimized in-Order and Request Streaming for PCI to DRAM 
Queue Accesses Enables Native Signal 

— Full Symmetric Multi-Processor Processing (NSP) on Systems 
(SMP) Protocol for up to Two Designed With the Pentium Pro 
Processors Processor 

— Dynamic Deferred Transaction — Integrated Arbiter With Multi- 
Support Transaction PCI Arbitration 

— GTL+ Compliant Host Bus Accelerator Hooks 

— Supports USWC Cycles — 5 PCI Bus Masters are Supported in 

| Integrated DRAM Controller Addition to the Host and PCI-to-ISA 

— 8 MB to 1 GB Main Memory V/0 Bridge ; 

— 64/72-Bit Non-Interleaved Path to _ Delayed Transaction Support : 
Memory — PCI Parity Checking and Generation 

— FPM (Fast Page Mode), EDO Support 
(Extended Data Out -Page Mode), — Supports Concurrent Pentium Pro 
BEDO (Extended Data Out -Burst and PCI Transactions to Main 
Mode) DRAMs Providing x-222 to Memory 
x-4-4-4 Burst Capability = Data Buffering For Increased 

— Support for Auto Detection of Performance 
Memory Type: BEDO, EDO or FPM — Extensive CPU-to-DRAM and PCI-to- 

— 8 RAS Lines Available DRAM Write Data Buffering 

— Support for 4-, 16- and 64-Mb DRAM — Write Combining Support for CPU- 
Devices to-PCl Burst Writes 


— Support for Symmetrical and 


Asymmetrical DRAM Addressing = System Management Mode (SMM) 


— Configurable Support for ECC or oe 
Parity = 208-Pin PQFP PCI Bridge/ Memory 

— ECC with Single Bit Error Correction Controller (PMC), 208-Pin PQFP for the 
and Multiple Bit Error Detection 440FX PClset Data Bus Accelerator 

— Read-Around-Write Support for (DBX) 
Host and PCI DRAM Read Accesses 

— Supports 3.3V or 5V DRAMs 


The Intel 440FX PClset provides a highly integrated solution for systems based on one or two Pentium® Pro 
processors. The 440FX PClset consists of the 82441FX PCI and Memory Controller (PMC), the 82442FX 
Data Bus Accelerator (DBX), and the 82371SB PCI I/O IDE Xcelerator (PIIX3). The PMC and DBX provide a 
two-chip host-to-PCI bridge including the DRAM control function, the PCI interface, and the PCI arbiter 
function. The 440FX PClset supports EDO, FPM, and BEDO DRAM technologies. The DRAM controller 
provides support for up to eight rows of memory and optional DRAM error detection/correction or parity. The 
440FX PClset contains extensive buffering between all interfaces for high system data throughput and 
concurrent operations. 
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1.0. OVERVIEW 


The 440FX PClset consists of a host-to-PCl bridge and memory controller, and an I/O subsystem core that 
allows an optimized price/performance path for the next generation of personal computers based on the 
Pentium Pro processor. The host-to-PCl bridge consists of two components; the PCI Bridge/Memory 
Controller (PMC) and the Data Bus Accelerator (DBX). The PMC and the DBX includes the following 
functions. 


e Support for one/two Pentium Pro Processors at bus frequencies up to 66 MHz 

e 64-bit GTL+ based host bus data interface 

e 32-bit host address support 

e 32-bit PCI bus interface 

e 64/72-bit main memory interface 

e Extensive data buffering between all interfaces for high throughput and concurrent operations 
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Figure 1. 440FX PClset System Block Diagram 
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The PMC and the DBxX interface with the Pentium Pro processor host bus. A maximum of two Pentium Pro 
processors are supported on the Pentium Pro host bus in a two processor symmetrical multi-processing 
configuration. A 16-bit private data bus (PD[15:0]) operating at host frequency between the DBX and the 
PMC provides a high throughput indirect interface between the DBX and PCI bus. 


The PMC and the DBX host bus interfaces are designed based on the GTL+ specification. The PMC/DBX 
also provides a 5.0V tolerant 3.3V main memory interface that allows support of either 5V or 3V DRAMs. The 
PMC connects directly to the 5V PCI bus. The PMC includes an internal PCI arbiter. 


The PIIX3 provides the PCl-to-ISA bridge functions along with Universal Serial Bus (USB) support. In 
addition, the PIIX3 contains a local bus master IDE interface and an interface for the 1/O APIC component 
required for second Pentium Pro processor support. The PIIX3 is compliant to the PCI Rev. 2.1 specification. 


Host Interface 


The PMC provides bus control signals and address paths for transfers between the host bus, PCI bus, and 
main memory. The PMC supports an optimized in-order queue that allows for pipelining of outstanding 
transaction requests on the host bus. 


During Host to PCI cycles, the PMC controls the PCI protocol and data flows through the DBX and PMC via 
the private bus (PD[15:0]). This bus operates at the host bus clock frequency. 


The PMC also receives addresses from PCI bus initiators for PCl-to-DRAM transfers. These addresses are 
translated to the appropriate memory addresses and are also provided on the host bus for snoop cycles. PCI 
master cycles are sent to main memory through the PMC with data moving over the PD bus to the DBX, 
which subsequently forwards the data to DRAM. 


DRAM Interface 


The PMC integrates a main memory controller that supports a 64/72-bit DRAM interface. The PMC DRAM 
controller interface supports the following features: 


e DRAM type: standard Fast Page Mode(FPM), Extended Data Out (EDO) (sometimes referred to as 
Hyper Page Mode) and Burst EDO (BEDO) memory. 


e Memory Size: 8 Mbytes to 1 Gbytes with eight RAS lines available. 

e Addressing Type: Symmetrical and Asymmetrical addressing 

e Memory Modules supported: Single and double density SIMMs and DIMMs 

e DRAM device technology: 4 Mbit, 16 Mbit, and 64 Mbit 

e DRAM Speeds: 50, 60, and 70 ns 

The memory controller provides capability for auto-detection of BEDO/EDO/FPM DRAM type installed in the 
system during system configuration and initialization providing a Plug and Play DRAM interface to the user. 
The PMC/DBX also provides data integrity features including ECC in the memory array and parity error 
detection. During host and PCI reads of the DRAM, the DBX provides error checking and correction of the 
data. The DBX supports multiple-bit error detection and single-bit error correction wnen ECC mode is enabled 


and parity error detection when parity mode is enabled. During host or PC] master writes to DRAM, the DBX 
generates ECC/Parity for the data. 
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DBX 


A single DBX provides a 64-bit CPU-to-main memory data path. The DBX also interfaces to the 16-bit private 
data bus for PCI transactions and PMC configuration register set access. The private bus operating at host 
frequency provides enough throughput to sustain PCI bandwidth. The DBX allows for a cost effective solution 
providing optimal CPU-to-DRAM performance while maintaining a relatively small footprint (208 pins). 


PCI Interface 


The PCI interface is 5V Revision 2.1 compliant and supports up to five PCI bus masters in addition to the 
PIIX3 components. The PMC supports a divide-by-2 synchronous PCI coupling to the host bus frequency. 


IOAPIC 


The IOAPIC component supports dual processors as well as enhanced interrupt processing in the single 
processor environment. No special interface is required on the PMC in this case. The PMC furnishes an 
external status output signal to the standalone I|OAPIC component that is used for buffer flushing during 
synchronization events for the PIIX3. 


2.0. SIGNAL DESCRIPTION 


This section provides a detailed description of each signal. The signals are arranged in functional groups 
according to their associated interface. 


The “#” symbol at the end of a signal name indicates that the active, or asserted state occurs when the signal 
is at a low voltage level. When “#” is not present after the signal name the signal is asserted when at the high 
voltage level. 


The terms assertion and negation are used extensively. This is done to avoid confusion when working with a 
mixture of ”active-low” and "active-high” signals. The term assert, or assertion indicates that a signal is 
active, independent of whether that level is represented by a high or low voltage. The term negate, or 
negation indicates that a signal is inactive. 


The following notations are used to describe the signal and type: 
I Input pin 
O Output pin 
OD Open Drain Output pin. This requires a pull-up to the VCC of the processor core 
/O Bi-directional Input/Output pin 
The signal description also includes the type of buffer used for the particular signal: 
GTL+ Open Drain GTL+ interface signal. Refer to the GTL+ I/O Specification for complete details 
~ PCl PCI bus interface signals. These signals are compliant with the PCI 5.0V Signaling Environment 


DC and AC Specifications 
LVTTL Low Voltage TTL compatible signals. These are also 3.3V outputs with 5V tolerant inputs. 
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INITIALIZATION: INIT# is asserted (soft reset) by the PMC during a CPU 
shutdown bus cycle, or after the writing to the reset control register to initiate a 
soft reset. 


ADDRESS BUS: HA[31:3]# connects to the CPU address bus. The PMC drives 
HA[31:3]# during snoop cycles on behalf of PCI initiators. Note that the CPU 
address bus is an inverted bus. 


ADDRESS STROBE: The CPU bus owner asserts ADS# to indicate the first of 
two cycles of a request phase. 


BLOCK NEXT REQUEST: Used to block the current request bus owner from 
issuing new requests. This signal is used to dynamically control the CPU bus 
pipeline depth. 


PRIORITY AGENT BUS REQUEST: The owner of this signal will always be the 
next bus owner. This signal has priority over symmetric bus requests and causes 

the current symmetric owner to stop issuing new transactions unless the HLOCK# 
signal is asserted. The PMC drives this signal to gain control of the CPU bus. 


DBSY# 1/0 DATA BUS BUSY: Used by the data bus owner to hold the data bus for transfers 
requiring more than one cycle. 


DEFER: The PMC uses a dynamic deferring policy to optimize for system 
performance. The PMC also uses the DEFER# signal to indicate a CPU retry 
response. 


DRDY# 1/0 DATA READY: Asserted for each cycle that data is transferred. 
GTL+ | 
FLUSH# OD FLUSH: Issued to CPU(s) for L1/L2 cache for a write back of all cache lines in 
LVTTL | modified state and then invalidate all cache lines. This signal is asserted by the 
PMC to throttle the CPU bus in the deturbo mode of operation. 
| HIT# 1/0 
GTL+ 
HITM# 1/0 
GTL+ 


HLOCK# | 
GTL+ 


HREQ/[4:0]# | 1/O 
GTL+ 


HIT: Indicates that a caching agent holds an unmodified version of the requested | 
line. Also, driven in conjunction with HITM#, by the target, to extend the snoop 
window. 


HIT MODIFIED: Indicates that a caching agent holds a modified version of the 
requested line and that this agent assumes responsibility for providing the line. 
Also, driven in conjunction with HIT# to extend the snoop window. 


HOST LOCK: All CPU bus cycles sampled with the assertion of HLOCK# and 
ADS#, until the negation of HLOCK# must be atomic (i.e., no PCI activity to 

DRAM is allowed and the locked cycle is translated to PCI, if targeted for the PCI 
bus.) 


REQUEST COMMAND: Asserted during both clocks of the request phase. In the 
first clock, the signals define the transaction type to a level of detail that is 
sufficient to begin a snoop request. In the second clock, the signals carry 
additional information to define the complete transaction type. 
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HTRDY# I/O HOST TARGET READY: Indicates that the target of the CPU transaction is able 
GTL+ to enter the data transfer phase. | 


RS[2:0]# RESPONSE SIGNALS: Indicates the type of response: 
GTL+ 


RS[2:0] Response type 
Note: All of the signals in the host interface are described in the Pentium Pro datasheet. The preceding table 
highlights 440FX PClset specific uses of these signals. 


000 Idle state 

001 Retry response 

010 Defer response 

011 Reserved 

100 Hard Failure 

101 Normal without data 
110 Implicit Writeback 


Normal with data 


2.1.2. | DRAMINTERFACE (PMC) 


CAS[7:0]# |O COLUMN ADDRESS STROBE: The CASJ[7:0]# signals are used to latch the 
LVTTL | column address on the MA[11:0] lines into the DRAMs. These signals drive the 
DRAM array directly without external buffering. 


MEMORY ADDRESS: MA[11:2] provide multiplexed row and column address to 
DRAM. MA[11:2] are externally buffered to drive the address lines of the DRAM. 


MAA[1:0] O LOWER MEMORY ADDRESS SET A: MAA(1:0] are the lower two bits of the 
LVTTL | memory address used to complete the row and column address to the DRAM. 
These two pins are toggled during the burst phase. | 
RAS[7:6]#/ | O ROW ADDRESS STROBES RAS7# AND RAS6# OR LOWER MEMORY 
MAB[1:0] LVTTL: | ADDRESS SET B: MAB[1:0] are the lower two bits of the memory address used to 
complete the row and column address to the DRAM. These signals are toggled 
during the burst phase. RAS[7:6]# are used to latch the row address on the 
MA[1 1:0] lines into the DRAMs. These signals should be used to select the upper 


two rows in the memory array. These signals drive the DRAM array directly without 
external buffers. 


The strapping on PC8 selects the function of these pins. 


RAS[5:0]# |O ROW ADDRESS STROBE: The RASJ[5:0]# signals are used to latch the row 
LVTTL | address on the MA[11:0] lines into the DRAMs. Each signal is used to select one 
DRAM row. These signals drive the DRAM array directly without any external 


buffers. 


WE# O WRITE ENABLE SIGNAL: WE+# is asserted during writes to main memory. During 
LVTTL | burst writes to main memory, WE# is externally buffered to drive the WE# inputs of 
the DRAM. 
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PCI ADDRESS/DATA: These signals are connected to the PCI address/data bus. 


AD[31:0] | 1/0 
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PCI Address is driven by the PMC with FRAME# assertion, data is driven or received in 
following clocks. 


DEVSEL# | 1/0 
PCI 


FRAME# I/O 
PCI 


IRDY# 


PLOCK# 


1/0 
PCl 


TRDY# 


a mt eh et et met met ot OO OOO OC O 
—~ ast es SH OO C0 HA +H +" 0 0 OO 
== 0 O- = odoj7a += oo = Xo 
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DEVICE SELECT: Device select, when asserted, indicates that a PCI target device 
has decoded its address as the target of the current access. The PMC asserts 
DEVSEL# based on the DRAM address range being accessed by a PCI initiator or 
if it decodes the current configuration cycle is targeted to the PMC. 


FRAME: FRAME+# is an output when the PMC acts as an initiator on the PCI Bus. 
FRAME# is asserted by the PMC to indicate the beginning and duration of an 
access. The PMC asserts FRAME# to indicate a bus transaction is beginning. 


/O INITIATOR READY: IRDY# is an output when PMC acts as a PCI initiator and an 
PCI input when the PMC acts as a PCI target. The assertion of IRDY# indicates the 
transaction. 


PLOCK: PLOCK# indicates an exclusive bus operation and may require multiple 
transactions to complete. When PLOCK¢# is asserted, non-exclusive transactions 
may proceed. A grant to start a transaction on the PCI Bus does not guarantee 
control of the PLOCK# signal. Control of the PLOCK# signal is obtained under its 
own protocol in conjunction with the GNT# signal. The PMC supports bus lock 
mode of operation. 


0 


current PCI Bus initiator's ability to complete the current data phase of the 


output when the PMC acts as a PCI target. The assertion of TRDY# indicates the 
target agent's ability to complete the current data phase of the transaction. 


C/BE[3:0]# | I/O COMMAND/BYTE ENABLE: PCI Bus Command and Byte Enable signals are 
PCl multiplexed on the same pins. During the address phase of a transaction, 
C/BE[3:0]# define the bus command. During the data phase C/BE[3:0]# are used as 
byte enabies. The byte enables determine which byte lanes carry meaningful data. 
PCi Bus command encoding and types are listed below. 
C/BE[3:0]# 
0 
_ Memory Write and Invalidate 


TARGET READY: TRDY# is an input when the PMC acts as a PCI initiator and an 
PCI 


Command Type 
Interrupt Acknowledge 
Special Cycle 

I/O Read 

I/O Write 

Reserved 

Reserved 

Memory Read 
Memory Write 
Reserved 

Reserved 
Configuration Read 
Configuration Write 
Memory Read Multiple 
Reserved (Dual Address Cycle) 
Memory Read Line 
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PARITY: PAR is driven by the PMC when it acts as a PCI initiator during address 
PCl 


and data phases for a write cycle, and during the address phase for a read cycle. 
PAR is driven by the PMC when it acts as a PCI target during each data phase of a 
PERR# [/O 
PCl 


PCI memory read cycle. Even parity is generated across AD[31:0] and C/BE[3:0]#. 


PCI PARITY ERROR: Pulsed by an agent receiving data with bad parity one clock 
after PAR is asserted. The PMC generates PERR# active if it detects a parity error 
on the PCI bus and the PERR# Enable bit is set. 


SYSTEM ERROR: The PMC can be programmed to assert SERR# for 2 types of 
memory error conditions: 


1. Main memory single bit ECC error 
2. Main memory (DRAM) parity or multiple bit ECC error 


The PMC can be programmed to assert SERR# when it detects a target abort on a 
PMC initiated PCI cycle and when PERR# is sampled active. 


PCIRST# O PCI RESET: PCI bus reset forces the PCI interfaces of each device to a known 
PCI state. The PMC generates a minimum 1 ms pulse for PCIRST#. 


STOP# /O 
PCl 


SERR# O 


STOP: STOP# is an input when the PMC acts as a PCI initiator and an output when 
the PMC acts as a PCI target. STOP# indicates that the bus initiator must 
immediately terminate its current PCI Bus cycle at the next clock edge and release 
control of the PCI Bus. STOP# is used for disconnect, retry, and abort sequences 
on the PCI Bus. 


2.1.4. PCI SIDEBAND INTERFACE (PMC) 


PHOLD# PCI HOLD: The PIIX3 asserts this signal to request the PCI bus. 
| PCl | : 
PHLDA# O PCI HOLD ACKNOWLEDGE: The PMC asserts this signal to grant PC] bus 
PCl ownership to the PIIX3. | 


WSC# O WRITE SNOOP COMPLETE: Asserted to indicate that all that the snoop activity on 
PCl the CPU bus on behalf of the last PCl-to-DRAM write transaction is complete. 

REQ[4:0]# || PCI BUS REQUEST: REQ/[4:0]# are the PCI bus request signals used by the PMC 
PCl for PCI initiator arbitration. 

GNT[4:0]# | O PCI GRANT: GNT[4:0]# are the PCI bus grant signals used by the PMC for PCI 
PCI initiator arbitration. 
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2.1.5. DBX INTERFACE (PMC) 


A 


DBX_ERR# || DBX ERROR: Asserted by the DBX if an ECC or parity error occurred during a 
LVTTL | memory cycle. DBX_ERR# is asserted for 5 host clocks to indicate a Single-bit 
ECC error and 6 host clocks to indicate a parity or Multi-bit ECC error. 
HLAD# O HOST LATCH AND ADVANCE: During CPU reads (both from DRAM and PC), 
LVTTL | this signal controls the latching of the read data into the DBX CPU interface output 
latch. 
MLAD O MEMORY LATCH AND ADVANCE: During DRAM reads, asserting this signal 
LVTTL | latches memory read data into the DBX. During DRAM writes, asserting this signal 
latches write data out of the DBX. 
PC[8:0] 1/O PMC CONTROL SIGNALS: PC[8:0] are control signals between the PMC and 
LVTTL | DBX. 
PD[15:0] 1/0 PRIVATE DATA BUS: This is a 16 bit private data path between the PMC and 
LVTTL | DBX. This bus runs at the host clock rate and is used to transfer data during CPU- 
to-PCl cycles and PCI to DRAM cycles 
DDRDY# O DELAYED DATA READY: This delayed version of the DRDY# signal is asserted 
LVTTL | by the PMC to the DBX. 


2.1.6. | CLOCKS (PMC) 


HCLKIN 


| HOST CLOCK IN: This pin receives a host clock input from an external clock source. 
2.5V The input is configurable via the PD1 strap. If the PD1 is sampled low at 
LVTTL 


reset(default), 3.3V buffer mode is enabled. This is normal operation enabled by 
internal pulldowns. If PD1 is sampled high, 2.5V buffer mode is enabled. 


PCLKIN || PCI CLOCK IN: This pin receives a PCI clock reference that is synchronous with 
LVTTL | respect to the host clock. This is the PCI clock reference that can be synchronously 
derived by an external clock synthesizer component from the host clock (divide-by-2). 


This signal clocks the PMC logic that is in the PCI clock domain. 


2.1.7. MISCELLANEOUS (PMC) 
[Nene [ye [SSCSCSCSC« pow 


CRESET# |O CHIP RESET: This is a reset output signal driven by the PMC to the DBX. 
LVTTL CRESET# is driven active for 2 msec. The DBX drives CPURST# to the CPUs, 


which is a 2 host clocks delayed version of the CRESET#. The PMC can also 
activate CRESET# under software control by writing to the internal reset 
configuration regsiter to initiate a hard reset or CPU BIST. 


GTL_REFV | GTL+ REFERENCE VOLTAGE: This is the reference voltage derived from the 
termination voltage to the pullup resistors and determines the noise margin for the 
signals. 
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PWROK POWER OK: This input goes active after all the power supplies in the system have 
LVTTL 


reached their specified values. PWROK forces all of the PMC internal state 
2.1.8. POWER UP STRAP OPTIONS (PMC) 


machines to their default values. PWROK inactive generates CPURST# and 
PCIRST# active. The rising edge of PWROK is asynchronous, but must meet set- 
up and hold specifications for recognition on any specific clock. The PMC holds 
CPURST# for 2 msec and PCIRST# active for 1 msec after the rising edge of 
PWROK. 


Below is a list of all power on options that are loaded into the PMC based on the voltage level present on the 
respective strappings at the rising edge of PWROK. The PMC floats all signals connected to straps during 
CRESET# and keeps them floated for a minimum of 4 host clocks after the negation of CRESET#. To enable 
the different modes, external pullups should be approximately 10 KQ to 3.3V (does not apply to A7#). Note 
that all signals that are used to select powerup strap options are connected to weak internal pulldowns. 


Register Description 
Name/bit 


PMCCFG[14] Rows 7 And 8 Enable: PC8 selects if RAS[7:6]#/ MAB[1:0] pins are used as 


row selects or extra copies of the lower two memory addresses. These are 
selected as follows: 
PC8 RAS[7:6]/MAB[1:0] 


0 MAB[1:0] 
RASI7:6]# 


66 MHz 
Reserved 


Test Mode: See Testability Section 


HCLKIN Input Buffer Select: PD1 selects whether the 2.5V or 3.3V mode is 
enabled. 


PC[3:2] PMCCFG[9:8] | Host Frequency Select: PC[3:2] selects the CPU bus frequency. 
PC[3:2] CPU Bus Frequency 
00 Reserved 
01 60 MHz 


PD[15:12] 


HCLKIN Input Buffer Select 


3.3V Input (Default) 
2.5V Input 


PMCCFG2 
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In-order Queue Depth Select/Enable: The value on A7# sampled on the 
rising edge of CRESET# reflects if the |OQD is set to 1 or maximum of four. 
Note that A7# is pulled up as a GTL+ signal and can be driven by to zero by 
external logic. 
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2.2. DBX Signals 


2.2.1. DRAM INTERFACE SIGNALS (DBX) 


MD([63:0] | I/O MEMORY DATA: These signals are connected to the DRAM data bus and have weak 
LVTTL | internal pulldowns. 


MPD[7:0] | I/O MEMORY PARITY DATA: These signals are connected to the parity or ECC bits of 
LVTTL | the DRAM data bus and have weak internal puilldowns. 
2.2.2. PMC INTERFACE SIGNALS (DBX) 


DBX ERROR: DBX_ERR# is generated for ECC or parity errors during a memory 
read cycle. DBX_ERR# is asserted for 5 host clocks to indicate a Single-bit ECC 
error and 6 host clocks to indicate a parity or Multi-bit ECC error. 


HLAD# | HOST LATCH AND ADVANCE SIGNAL: During CPU reads, HLAD# controls the 
LVTTL | latching of read data into the DBX CPU interface output latch. 


MLAD MEMORY LATCH AND ADVANCE SIGNAL: During DRAM reads, the PMC 
asserts this signal to latch memory read data into the DBX. During DRAM writes, 
the PMC asserts this signal to latch write data from the DBX. 


PMC DBX CONTROL SIGNALS: PC[8:0] are control signals between the PMC 
and DBX. 


DELAYED DATA READY: The PMC asserts this delayed version of DRDY# to 
the DBX. 


PD[15:0] 1/0 PRIVATE DATA BUS: These signals are connected to the PD data bus on the 
LVTTL | PMC. This is the data path for the PCI-to-DRAM and CPU-to-PCI cycles. During 
PCl-to-DRAM reads and CPU-to-PCl writes, the DBX drives data on this bus. 


During CPU-to-PCI reads and PCI-to-DRAM writes, the DBX receives data on 
this bus. 


HOST INTERFACE SIGNALS (DBX) 


2.2.3. 
HD[63:0]# | I/O HOST DATA: These signals are connected to the CPU data bus. Note that the data 
GTL+ | signals are inverted on the CPU bus. 
CPURST# |O CPU RESET: The CPURST# pin is an output from the DBX that is driven directly 
GTL+ | from the CRESET#. It allows the CPUs to begin execution at a known state. 
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2.2.4. MISCELLANEOUS (DBX) 


OS 


HCLKIN | HOST CLOCK IN: This pin receives a host clock input from an external source. The 
2.5V input is configurable via the PD1 strap. If the PD1 is sampled low at reset (default), 
LVTTL | 3.3V buffer mode is enabled. This is normal operation enabled by internal 


pulldowns. If PD1 is sampled high, 2.5V buffer mode is enabled. 
termination voltage to the pullup resistors and determines the noise margin for the 
BREQO# O SYMMETRIC AGENT BUS REQUEST: Driven by the DBX during CPURST# to 
GTL+ configure the symmetric bus agents. 


CRESET# || CHIP RESET: This is a reset input signal driven by the PMC to the DBX. It forces 
the DBX to begin execution in a known state. This signal is also used to drive the 
LVTTL | CPURST# to the CPUs. 
signals. This signal goes the reference input of the GTL+ sense amp on each GTL+ 
2.2.5. POWER UP STRAP OPTIONS (DBX) 


GTL_REFV GTL REFERENCE VOLTAGE: This is the reference voltage derived from the 
input or I/O pin. 


Below is a list of all power on options that are loaded into the DBX, based on the voltage level present on the 
respective strappings at the rising edge of CRESET#. To enable the different modes, external pullups should 
be approximately 10 KQ to 3.3V. Note that all signals that are used to select powerup strap options are 
connected to weak internal pulldowns. 


Register Description 
Name/bit 


PD[5:2] a Test Mode: See Testability Section 
PD1 


HCLKIN Input Buffer Select: PD1 selects whether the 2.5V or 3.38V mode is 
enabled. 
HCLKIN Input Buffer Select 
3.3V Input (Default) 
2.5V Input 
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3.0. REGISTER DESCRIPTION 


The PMC contains two sets of software accessible registers (I/O Mapped and Configuration registers), 
accessed via the Host CPU I/O address space. The I/O Mapped registers control access to PCI configuration 
space. Configuration Registers reside in PCI configuration space and specify PCI configuration, DRAM 
configuration, operating parameters, and optional system features. 


The PMC internal registers (both 1/O Mapped and Configuration registers) are accessible by the Host CPU. 
The registers can be accessed as Byte, Word (16-bit), or Dword (32-bit) quantities, with the exception of 
CONFADD which can only be accessed as a Dword. All multi-byte numeric fields use "little-endian" ordering 
(i.e., lower addresses contain the least significant parts of the field). The following nomenclature is used for 
access attributes. 


RO Read Only. If a register is read only, writes to this register have no effect. 

R/W Read/Write. A register with this attribute can be read and written. 

R/WC  ==Read/Write Clear. A register bit with this attribute can be read and written. However, a write of 1 
clears (sets to 0) the corresponding bit and a write of 0 has no effect. 


some of the PMC registers described in this section contain reserved bits. Software must deal correctly with 
fields that are reserved. On reads, software must use appropriate masks to extract the defined bits and not 
rely on reserved bits being any particular value. On writes, software must ensure that the values of reserved 
bit positions are preserved. That is, the values of reserved bit positions must first be read, merged with the 
new values for other bit positions and then written back. 


In addition to reserved bits within a register, the PMC contains address locations in the PCI configuration 
space that are marked "Reserved" (Table 3-1). The PMC responds to accesses to these address locations by 
completing the host cycle. When a reserved register location is read, a zero value is returned. Software 
should not write to reserved PMC configuration locations in the device-specific region (above address offset 
3Fh). 


During a hard reset, the PMC sets its internal configuration registers to predetermined default states. The 
default state represents the minimum functionality feature set required to successfully bring up the system. 
Hence, it does not represent the optimal system configuration. It is the responsibility of the system 
initialization software (usually BIOS) to properly determine the DRAM configurations, operating parameters 
and optional system features that are applicable, and to program the PMC registers accordingly. 


Note: The 440FX PCliset depends on the atomicity of configuration cycles in a 2-way SMP system. Thus, 
software (BIOS or OS) must guarantee that in a system with two processors only one processor can 
access the configuration space at any time. During system initialization, only the “Boot Processor” 
must be allowed access to configuration space. Additionally, PnP BIOS and EISA configuration 
utilities must guarantee that addresses OCF8h to OCFFh are allocated as motherboard addresses and 
not available as |/O locations. 


3.1. 1/0 Mapped Registers 
The PMC contains two registers that reside in the CPU I/O address space—the Configuration Address 
(CONFADD) Register and the Configuration Data (CONFDATA) Register. The Configuration Address 


Register enables/disables the configuration space and determines what portion of configuration space is 
visible through the Configuration Data window. 
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3.1.1. CONFADD—CONFIGURATION ADDRESS REGISTER 


/O Address: OCF8h (Accessed as a Dword) 
Default Value: 00000000h 


Access: Read/Write 


CONFADD is a 32-bit register accessed only when referenced as a Dword. A Byte or Word reference will 
“pass through" the Configuration Address Register to the PC! Bus. The CONFADD Register contains the Bus 
Number, Device Number, Function Number, and Register Number for which a subsequent configuration 
access is intended. 


i 
Configuration Enable (CONE). 1=Enable. 0=Disable. 


Bus Number (BUSNUM). When BUSNUM is programmed to 00h, the target of the configuration 


23: 
cycle is either the PMC or the PCI Bus that is directly connected to the PMC, depending on the 
Device Number field. If the Bus Number is programmed to 00h and the PMC is not the target, a type 
15:11 
10:8 
7:2 


0 configuration cycle is generated on PCI. If the Bus Number is non-zero, a type 1 configuration 
cycle is generated on PCI with the Bus Number mapped to AD[23:16] during the address phase. 

) function as specified by the other fields in the Configuration Address Register. This field is mapped 
to AD[7:2] during PCI configuration cycles. 


3.1.2. CONFDATA—CONFIGURATION DATA REGISTER 


Device Number (DEVNUM). This field selects one agent on the PCI Bus selected by the Bus 
Number. During a Type 1 Configuration cycle, this field is mapped to AD[15:11]. During a Type 0 
configuration cycle, this field is decoded and one of AD[31:11] is driven to 1. The PMC is always 
Device Number 0. 


Function Number (FUNCNUM). This field is mapped to AD[10:8] during PCI configuration cycles. 
This allows the configuration registers of a particular function in a multi-function device to be 
accessed. The PMC responds to configuration cycles with a function number of 000b; all other 
function number values attempting access to the PMC (Device Number = 0, Bus Number = 0) 
generate a type 0 configuration cycle on the PCI Bus with no IDSEL asserted, which results in a 
master abort. 


Register Number (REGNUM). This field selects one register within a particular bus, device, and 


1/O Address: OCFCh 
Default Value: 00000000h 
Access: Read/Write 


CONFDATA is a 32-bit read/write window into configuration space. The portion of configuration space that is 
referenced by CONFDATA is determined by the contents of CONFADD. 


a 


Configuration Data Window (CDW). If bit31 of CONFADD is 1, any I/O reference in the 
CONFDATA I/O space is mapped to configuration space using the contents of CONFADD. 
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3.2. PCI Configuration Space Mapped Registers 


The PCI Bus defines a slot based "configuration space" that allows each device to contain up to 256 8-bit 
configuration registers. The PCI specification defines two bus cycles to access the PCI configuration space— 
Configuration Read and Configuration Write. While memory and I/O spaces are supported by the Pentium 
microprocessor, configuration space is not supported. The PCI specification defines two mechanisms to 
access configuration space, Mechanism #1 and Mechanism #2. The PMC only supports Mechanism #1 (both 
type 0 and 1 accesses). Table 1 shows the PMC configuration space. 


The configuration access mechanism makes use of the CONFADD Register and CONFDATA Register. To 
reference a configuration register, a Dword I/O write cycle is used to place a value into CONFADD that 
specifies the PCI Bus, the device on that bus, the function within the device, and a specific configuration 
register of the device function being accessed. CONFADD[31] must be 1 to enable a configuration cycle. 
Then, CONFDATA becomes a window onto four bytes of configuration space specified by the contents of 
CONFADD. Read/write accesses to CONFDATA generates a PCI configuration cycle to the address 
specified by CONFADD. 


3.2.1. PCI CONFIGURATION ACCESS 


Type 0 Access: If the Bus Number field of CONFADD is 0, a type 0 configuration cycle is generated on PCI. 
CONFADD/[10:2] is mapped directly to AD[10:2]. The Device Number field of CONFADD is decoded onto 
AD[31:11]. The PMC is Device #0 and does not pass its configuration cycles to PCI. Thus, AD11 is never 
asserted. (For accesses to device #1, AD12 is asserted, etc., to Device #20 which asserts AD31.) Only one 
AD line is asserted at a time. All device numbers higher than 20 cause a type 0 configuration access with no 
IDSEL asserted, which results in a master abort. 


Type 1 Access: If the Bus Number field of CONFADD is non-zero, a type 1 configuration cycle is generated 


on PCI. CONFADD[23:2] are mapped directly to AD[23:2]. AD[1:0] are driven to 01 to indicate a Type 1 
Configuration cycle. All other lines are driven to 0. 
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Table 1. PMC Configuration Space 
Address 


Register Register Name 
Offset Symbol 


RID | Revision Identification 


° 
. 


Reserved 


9—OBh CLASSC Class Code 


0 
OCh 
[DBC [DEX Buiter Conteh 
[DRAMA 


5 
5 
san [AxC[Aunliay Conti 
5 
5 
5 


RO 
RO 
alain 
ee 
7 
a 
oe 
ae 
ein 
ane 


70h 
71h 


72h SMRAM 


73-8Fh 


MTT 

CLT 
sr 
=a 


9 Turbo Reset Control Register 
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3.2.2. VID—VENDOR IDENTIFICATION REGISTER 


Address Offset: 00-—O1h 
Default Value: 8086h 
Attribute: Read Only 


The VID register contains the vendor identification number. This 16-bit register combined with the Device 
Identification register uniquely identify any PCI device. Writes to this register have no effect. 


Oe 


Vendor Identification Number. This is a 16-bit value assigned to Intel. Intel VID = 8086h. 


3.2.3. DID—DEVICE IDENTIFICATION REGISTER 


Address Offset: 02—03h 
Default Value: 1237h 
Attribute: Read Only 


This 16-bit register combined with the Vendor Identification register uniquely identifies any PC! device. Writes 
to this register have no effect. 


Fe 
| 15:0 | Device Identification Number. This is a 16 bit value assigned to the PMC. 


3.2.4. PCICMD—PCI COMMAND REGISTER 


Address Offset: 04—05h 
Default Value: OO006h 
Attribute: Read/Write 


This 16-bit register provides basic control over the PMC's ability to respond to PCI cycles. The PCICMD 
register enables and disables the SERR# signal, the parity error signal (PERR#), PMC response to PCI 
special cycles, and enables and disables PCI master accesses to main memory. 


{2 ON SRN 
a. Fast Back-to-Back. Not Implemented. This bit is harcwiied to 0. 


SERR# Enable (SERRE). If this bit is set to a 1, the PMC generates SERR# signal for all relevant 
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bits set in the ERRSTS and PCISTS registers as controlled with the corresponding bits of the 
ERRCMD register. If SERRE is reset to 0, then SERR# is never driven by the PMC. Address Parity 
error reporting as a target is enabled by the PERRE bit located in this register. 


Address/Data Stepping. Not Implemented. This bit is hardwired to 0. 
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Parity Error Enable (PERRE). PERRE controls the PMC’s response to PCI parity errors during 
data phase when PMC receives the data. If PERRE=1, these errors are reported on the PERR# 
signal. Note that, when PERRE=1, address parity errors are reported via the SERR# mechanism (if 
enabled via SERRE bit). If PERRE=0, parity errors are not signaled (i.e., PMC’s parity checking is 
disabled). 


Memory Write and Invalidate Enable. Not Implemented. This bit is hardwired to 0. 


Special Cycle Enable. Not Implemented. This bit is hardwired to 0. 


Bus Master Enable (BME). Not Implemented. This bit is hardwired to 1 (PMC bus master capability 
always enabled). 


Memory Access Enable ae Not Implemented. This bit is hardwired to 1 (PMC allows PCI. 
master access to main memory). 


I/O Access Enable (IOAE). Not Implemented. This bit is hardwired to 0 (PMC does not respond to 
PCI I/O cycles). 


3.2.5. PCISTS—PCI STATUS REGISTER 


Address Offset: 06—07h 
Default Value: 0280h 
Attribute: Read Only, Read/Write Clear 


PCISTS is a 16-bit status register that reports the occurrence of a PCI master abort and PCI target abort. 
PCISTS also indicates the DEVSEL# timing that has been set by the PMC hardware. Bits [15:12,8] are 
read/write clear and bits [10:9] are read only. 
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Detected Parity Error (DPE}—RWI/C. This bit is set to a 1 to indicate PMC’s detection of a parity 
error in either the data or address phase when it is the target of the PCI cycle. Software sets this bit 
to 0 by writing a 1 to it. Note that the function of this bit is not affected by the PERRE bit. 


Signaled System Error (SSE)}—RW/C. When the PMC asserts the SERR# signal, this bit is also set 
to 1. Software sets this bit to 0 by writing a 1 to it. 


Received Master Abort Status (RMAS}—RWI/C. When the PMC terminates a Host-to-PCl 
transaction (PMC is a PCI master) with an unexpected master abort, this bit is set to 1. Note that 
master abort is the normal and expected termination of PCI special cycles. Software sets this bit to 0 
by writing a 1 to it. 


Received Target Abort Status (RTAS}—RWIC. When a PMC-initiated PC! transaction is terminated 
with a target abort, RTAS is set to 1. The PMC also asserts SERR# if enabled in the ERRCMD 
register. Software sets this bit to 0 by writing a 1 to it. 


Signaled Target Abort Status (STAS)}—RW/C. When, as a PCI target, the PMC initiates a target 
abort to terminate a PCI transaction, STAS is set to a 1. Software sets this bit to 0 by writing a 1 to it. 


DEVSEL# Timing (DEVT)}—RO. This 2-bit field indicates the timing of the DEVSEL# signal when the 
PMC responds as a target, and is hard-wired to the value 01b (medium) to indicate the time when a 
valid DEVSEL# can be sampled by the initiator of the PCI cycle. 
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Data Parity Detected (DPD)}—RWIC. This bit is set to a 1, when conditions 1-3 below are met. 
Software sets this bit to 0 by writing a 1 to it. 

1. The PMC asserted PERR# or sampled PERR# asserted. 

2. The PMC was the initiator for the operation in which the error occurred. 

3. The PERRE bit in the PCI command register is set to 1. 


Fast Back-to-Back (FB2B)—RO. This bit is hardwired to 1, since the PMC as a target supports fast 


back-to-back transactions when transactions are to a different agent. 


Reserved. 


3.2.6. RID—REVISION IDENTIFICATION REGISTER 


Address Offset: O8h 
Default Value: xxh 
Attribute: Read Only 


This register contains the revision number of the PMC. These bits are read only and writes to this register 
have no effect. 


Description 


Revision Identification Number. This is an 8-bit value that indicates the revision identification 
number for the PMC. Please refer to Specification Update or Stepping Information for RID. 


3.2.7. CLASSC—CLASS CODE REGISTER 


Address Offset: 09—OBh 
Default Value: O60000h 
Attribute: Read Only 


This register contains the device programming interface information related to the Sub-Class Code and Base 
Class Code definition for the PMC. This register also contains the Base Class Code and the function sub- 
class in relation to the Base Class Code. 


a 
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3.2.8. MLT—MASTER LATENCY TIMER REGISTER 


Address Offset: ODh 
Default Value: 00h 
Attribute: Read/Write 


MLT is an 8-bit register that controls the amount of time the PMC, as a bus master, can burst data on the PCI 
Bus. The Count Value is an 8 bit quantity. However, MLT[2:0] are hardwired to 0. The PMC’s MLT is used to 
guarantee to the PCI agents (other than PMC) a minimum amount of the system resources. 


7:3 | Master Latency Timer Count Value. The number of clocks programmed in this field represents the 
guaranteed time slice (measured in PCI clocks) allotted to the PMC, after which it must complete the 


current data transfer phase and then surrender the bus as soon as its bus grant is removed. For 
example, if the MLT Register is programmed to 18h, then the value is 24 PCI clocks. The default 
value of MLT is 00h and disables this function. 


3.2.9. HEADT—HEADER TYPE REGISTER 


Address Offset: OEh 
Default: OOh 
Attribute: Read Only 


This register contains the Header Type of the PMC. This code is 00h indicating that the PMC’s configuration 
space map follows the basic format. This register is read only. 


Bit fo eseription 
Header Type (HTYPE): OOh=Basic configuration space format. 


3.2.10. BIST—BIST REGISTER 


Address Offset: OFh 
Default: OOh 
Attribute: Read/Write 


The Built In Self Test (BIST) function is not supported by the PMC. Writes to this register have no affect. 
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3.2.11. PMCCFG—PMC CONFIGURATION REGISTER 


Address Offset: 50—51h 
Default Value: xxh (some bits reflect hardware strapping options) 
Attribure: Read/Write, Read Only 


PMCCFG is a 16-bit register that is controls and logs the system level configuration. 


WSC Protocol Enable (WPE) —R/W. 1=Disable. O=Enable(default). This bit enables WSC 
protocol which is required for a two processor system using the IOAPIC. In a uniprocessor system, 
this bit should be disabled. 


— 
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Row Select or Extra Copy of Lower Memory Address Enable (ELME)—R0O. This bit reflects 
the value on PC8 sampled on the rising edge of PWROK. If this bit is set to 1, the two pins on the 
PMC are configured as two additional row selects (RAS[7:6]#). If this bit is set to a O (default), an 
extra copy of MAB[1:0] is enabled. 


Host Frequency Select (HFS)—RO. These bits reflect the polarity of the PC[3:2] sampled during 
the rising edge of PWROK. These bits are status bits only and writes to these bits have no affect. 
The values reflect the host bus frequency used: 


Host bus frequency 
Reserved 

60 MHz 

66 MHz 

Reserved 


Reserved. 


ECC/Parity TEST Enable (EPTE) —R/W. 1=ECC Test Mode. 0=Normal mode (default). When set, 
The PMC/DBX handles subsequent cycles to DRAM as described in the Functional Description 
section until this bit is written to 0. 


—_ 
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DRAM Data Integrity Mode (DDIM) —R/W. These bits provide software configurability of selecting 
ECC mode/parity or non-parity mode. Note that after reset, non-parity mode is enabled. BIOS 
should setup this field appropriately for the kind of SIMM installed in the system. 


DDIM DRAM Data Integrity Mode 

00 No Parity or ECC Checking (default) 
01 Parity Generation and Checking 
ECC Checking/Generation Enabled and Correction Disabled(SED/DED) 
ECC Checking/Generation Enabled and Correction Enabled(SEC/DED) 


2 In-Order Queue Depth (IOQD}—RO. 1=In-order Queue depth of 4. O=In-order queue depth of 1. 
This bit reflects value sampled on the A7# signal. 


A7# Electrical Value A7# Logical Value 1OQD Value Depth 
1.5V 0 1 4 
0.0 V 1 0 1 
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3.2.12. DETURBO—DETURBO COUNTER REGISTER 


Address Offset: 52h 
Default Value: OOh 
Access: Read/Write 


Some software packages rely on the operating speed of the processor to time certain system events. To 
maintain backward compatibility with these software packages, the PMC provides a mechanism to emulate a 
slower operating speed. DETURBO register supports a deturbo mode by providing a mechanism to stall the 
CPU bus pipeline using the BPRI# signal, at a rate programmed in this register. The deturbo mode must be 
first enabled in the TRC Register. 
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7:0 | DETURBO Count (DC). In the deturbo mode FLUSH# is held asserted to disable caching and the 
CPU bus pipeline is stalled at a rate determined by this field. Deturbo counter value is compared to 
an 8-bit counter running at the CPU system bus clock divided by 8. When the counter value is equal 
to the value specified in this register, BPRI# is asserted. BPRI# is negated when the counter rolls 
over to 00h and when it is less than this register value. The deturbo emulation speed is directly 
proportional to the value in this register. Smaller values in this register allows for slower emulation 
speed. 


3.2.13. DBC—DBX BUFFER CONTROL 


Address Offset: 53h 
Default Value: 80h 
Access: Read/Write 


This 8-bit register allows for DBX buffer control as well as control for the advanced features included in the 
PMC. 


NOTE 


All PMC testing assumes the features in this register are enabled. This register has been included only 
as a means to ensure functionality. No assumptions should be made about the existence of this 
register in the future versions of the PMC. 


Delayed Transaction Enable (DTE). 1=Enable (default). O0=Disable. When this bit is enabled, a read 
cycle from PCI to DRAM is immediately retried due to any pending CPU-to-PCI cycle. 


CPU-to-PCI IDE Posting Enable (CPIE). 1=Enable (01F0Oh and 0170h). O=Disable (default). When 
disabled, the cycles are treated as normal I/O write transactions. 


USWC Write Post During I/O Bridge Access Enable (UWPIO). 1=Enable. 0=Disable (default). 
When enabled, the PMC allows posting of CPU-to-PCI cycles destined for a USWC region, even 
| during a passive release cycle. 


PCI Delayed Transaction Timer Disable (DTD). 1=Disable. 1=Enable (default). When this bit is 
enabled, the PMC retries any PCI access that takes longer than 32 PCI clocks. 


CPU-to-PCI Write Post Enable (CPWE). 1=Enable. 0=Disable (default). This enables the CPU-to- 
PCI posting. 
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Description 


PCi-to-DRAM Pipeline Enable (PDPE). 1=Enable. 0=Disable (default). When this bit is disabled, it 
restricts pipelining of PCl-to-DRAM write cycles. 


PCli Burst Write Combining Enable (BWCE). 1=Enable. 0=Disable (default). When this bit is 


enabled, DBX is allowed to combine back-to-back sequential CPU-to-PCl writes (Dword or larger) into 
a single PCI write burst. 


Read-Around-Write Enable (RAWE). 1=Enable. 0=Disable (default). When disabled, all posted 
writes in the DBX are retired before a CPU or PCI read access is serviced. 


3.2.14. AXC—AUXILIARY CONTROL REGISTER 


Address Offset: 54h 
Default Value: 00h 
Access: Read/Write 


This 8-bit register controls auxiliary functions such as additional DRAM timings and memory I/O buffer 
strength. 
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RAS Precharge Enable (RPE). 1=4 host clocks. 0=3 host clocks (default). 


p[fesenes SSS 


Lower Memory Address Buffer Set A (LMAA). 1=8 mA for MAAI1:0]. 0= 12 mA for MAA[1:0]. This 


bit selects the I/O buffer strength of MAA[1:0] signals. 


hoe Reserved. 


PRELIMINARY a 


82441FX (PMC) AND 82442FX (DBX) I ntel ® 


3.2.15. DRT —DRAM ROW TYPE REGISTER 


Address Offset: 55-—56h 
Default Value: 0000h 
Access: Read/Write 


This 16-bit register identifies the type of DRAM (BEDO,EDO or FPM) used in each row, or if the row is empty. 
BIOS should program this register for optimum performance if BEDO or EDO DRAMs are used. The register 
also identifies if a particular row is left unpopulated and the total number of rows populated in the system. 
The hardware uses these bits to determine the correct cycle timing to use before a DRAM cycle is run. This 
register must be accessed as bytes. 
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15:0] DRAM Row Type (DRT). Each pair of bits in this register corresponds to the DRAM row identified by 
the corresponding DRB Register. 


DRT Corresponding DRB Register DRT Corresponding DRB Register 


DRT{[1:0] DRBO, row 0 DRT[9:8] DRB4, row 4 
DRT[3:2] DRB1, row1 DRT[11:10] DRB5, row 5 
DRT[5:4] DRB2, row 2 DRT[13:12] DRB6, row 6 
DRT[7:6] DRB3, row 3 DRT[15:14] DRB7, row 7 


The value programmed in each DRT bit pair uniquely identifies the DRAM timings used for the 
corresponding row. 


DRT Pair Corresponding DRB Register 
00 FPM mode 
01 EDO mode 


BEDO mode 
Empty Row 


3.2.16. DRAMC—DRAM CONTROL REGISTER 


Address Offset: 57h 
Default Value: Oth 
Access: Read/Write 


This 8-bit register controls main memory DRAM operating modes and features. 
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DRAM Refresh Queue Enable (DRQE). 1=Enable (The internal 4-deep refresh queue is enabled with 
the 4th request being the priority request. All refresh requests are queued.). O=Disable (default). All 
refreshes are priority requests. 


Note that all PMC testing will be done assuming this bit is always enabled. This bit has been included 
only as a means to ensure functionality. No assumptions should be made about the existence of this 
bit in the future versions of the PMC. 


5 DRAM EDO Auto-Detect Mode Enable (DEDM). When DEDM=1, a special timing mode for BIOS to 
detect EDO DRAM type on a row-by-row basis is enabled. 0=Disable (default). 


DRAM Refresh Type Select (DRFT). 1= RAS only. 0= CAS-before-RAS. 
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DRAM Refresh Rate (DRR). The DRAM refresh rate is adjusted according to value in this field. 
When normal is selected, the refresh rate is determined by the HFS field in the PMCCFG register. 
Note that refresh is also disabled via this field, and that disabling refresh results in the eventual loss of 
DRAM data. Note that changing DRR value resets the refresh request timer. The fast refresh mode 


implements a refresh cycle every 32 host clocks. 
Bits[2:0] Host Bus Frequency 


000 Refresh Disabled 
001 Normal 

01x Reserved 

1Xxx Reserved 

111 Fast Refresh 


3.2.17. DRAMT —DRAM TIMING REGISTER 


Address Offset: 58h 
Default Value: 10h 
Access: Read/Write 


This 8-bit register controls main memory DRAM timings. 


WCBR Mode Enable (WME). 1=Enable. 0=Disable. The WCBR programming mode for BEDO 
DRAMs is controlled by this bit and allows setting the BEDO DRAMs data mode in x86 toggle burst 
mode or linear burst mode. This bit should only be enabled by the BIOS during the BEDO DRAM 
auto-detect sequence as described in section 4.3. 


DRAM Read Burst Timing (DRBT). The DRAM read burst timings are controlled by the DRBT field. 
Slower rates may be required in certain system designs to support loose layouts or slower memories. 
Most system designs will be able to use one of the faster burst mode timings. The timing used 
depends on the type of DRAM on a per-row basis, as indicated by the DRT register. 


BEDO Rate EDO Rate FPM Rate 


X333 x444 x444 
X222 x333 x444 
X222 X222 X333 
Reserved Reserved Reserved 


DRAM Write Burst Timing (DWBT). The DRAM write burst timings are controlled by the DWBT 
field. Slower rates may be required in certain system designs to support loose layouts or slower 
memories. Most system designs will be able to use one of the faster burst mode timings. The timing 
used depends on the type of DRAM on a per-row basis, as indicated by the DRT register. 


BEDO/EDO Rate FPM Rate 
x444 x444 
X333 x444 
X333 x333 
X222 xX333 
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Description 


RASx# to CASx# Delay (RCD). 1=One clock between the assertion of RASx# and CASx#. 0=Zero 
clocks. This has no impact on e hit cases and affects only Row and Page misses. 


MA Wait State (MAWS). When MAWS = 1, one additional wait state is inserted before the assertion 
of the first MAxx and CASx#/RASx# assertion during DRAM read or write leadoff cycles. This affects 
page hit and row miss cases. When both MAWS and RCD bits are set, the MAWS functionality 
overrides. 


3.2.18. | PAM—PROGRAMMABLE ATTRIBUTE MAP REGISTERS (PAM[6:0]) 


Address Offset: PAMO (59h) — PAM6 (5Fh) 
Default Value: 00h 
Attribute: Read/Write 


The PMC allows programmable memory attributes on 13 memory segments of various sizes in the 640-Kbyte 
to 1-Mbyte address range. Seven Programmable Attribute Map (PAM) Registers are used to support these 
features. Cacheability of these areas is controlled via the MTRR registers in the CPU processor. Two bits are 
used to specify memory attributes for each memory segment. These bits apply to both CPU accesses and 
PCI initiator accesses to the PAM areas. These attributes are: 


RE Read Enable. When RE=1, CPU read accesses to the corresponding memory segment are claimed by 
the PMC and directed to main memory. Conversely, when RE=0, the CPU read accesses are directed 
to PCI. 


WE Write Enable. When WE=1, CPU write accesses to the corresponding memory segment are claimed 
by the PMC and directed to main memory. Conversely, when WE=0, the CPU write accesses are 
directed to PCI. 


The RE and WE attributes permit a memory segment to be read only, write only, read/write, or disabled. For 
example, if a memory segment has RE=1 and WE=0, the segment is read only. Each PAM Register controls 
two regions, typically 16-Kbyte in size. Each of these regions has a 4-bit field. The four bits that control each 
region have the same encoding and are defined Table 2. 


Table 2. Attribute Bit Assignment 


Bits [7,6, 3,2] Bits ANd 0] Description 
Reserved 


Disabled. DRAM is disabled and all accesses are directed to 
PCI. PMC does not respond as a PCI target for any read or 
write access to this area. 


Read Only. Reads are forwarded to DRAM and writes are 
forwarded to PCI for termination. This write protects the 
corresponding memory segment. PMC responds as a PCI 
target for read accesses but not for any write accesses. 


Write Only. Writes are forwarded to DRAM and reads are 
forwarded to the PCI for termination. PMC responds as a PCI 
target for write accesses but not for any read accesses. 


Read/Write. This is the normal operating mode of main 
memory. Both read and write cycles from the CPU are claimed 
by the PMC and forwarded to DRAM. PMC responds as a PCI 
target for both read and write accesses. 
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As an example, consider a BIOS that is implemented on the expansion bus. During the initialization process 
the BIOS can be shadowed in main memory to increase the system performance. When a BIOS is shadowed 
in main memory, it should be copied to the same address location. To shadow the BIOS, the attributes for 
that address range should be set to write only. The BIOS is shadowed by first doing a read of that address. 
This read is forwarded to the expansion bus. The CPU then does a write of the same address, which is 
directed to main memory. After the BIOS is shadowed, the attributes for that memory area are set to read 
only so that all writes are forwarded to the expansion bus. Table 3 shows the PAM registers and the 
associated attribute bits: 


Table 3. PAM Registers and Associated Memory Segments 
PAM Reg 


Attribute Bits Memory Segment 


PAM3[3:0] 
PAM3I7:4] 
PAM4[3:0] 
PAM4[7:4] 
PAM5[3:0] 
PAMSI7:4] 
PAM6[3:0] 
PAM6[7:4] 


; 
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DOS Application Area (Q0000-9FFFh). The DOS area is 640 Kbytes in size and it is further divided into two 
parts. The 512-Kbyte area at 0 to 7FFFFh is always mapped to the main memory controlled by the PMC, 
while the 128-Kbyte address range from 080000 to O9FFFFh can be mapped to PCI or to main DRAM. By 
default this range is mapped to main memory and can be declared as a main memory hole (accesses 
forwarded to PCl) via the FDHC Register 
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Video Buffer Area (AOOO0-BFFFFh). This 128-Kbyte area is not controlled by attribute bits. The CPU - 
initiated cycles in this region are always forwarded to PCI for termination. This area can be programmed as 
SMM area via the SMRAM register. 


Expansion Area (COO00-DFFFFh). This 128-Kbyte area is divided into eight 16-Kbyte segments which can 
be assigned with different attributes via PAM Control Register. 


Extended System BIOS Area (EQOO00-EFFFFh). This 64-Kbyte area is divided into four 16-Kbyte segments 
which can be assigned with different attributes via PAM Control Register. 


System BIOS Area (FOOOO-FFFFFh). This area is a single 64-Kbyte segment which can be assigned with 
different attributes via PAM Control Register. 
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3.2.19. DRB[0:7] —DRAM ROW BOUNDARY REGISTERS 


Address Offset: _DRBO (60h) — DRB7 (67h) 
Default Value: Oth 
Access: Read/Write 


The PMC supports 8 rows of DRAM. The memory data interface is 64 bits wide. The DRAM Row Boundary 
registers define upper and lower addresses for each DRAM row. Contents of these 8-bit registers represent 
the boundary addresses in 8-Mbyte granularity. For example, a value of 01h indicates 8 Mbyte. 


60h DRBO = Total memory in row0O (in 8 Mbytes) 

61hDRB1 = Total memory in row0 + row1 (in 8 Mbytes) 

62h DRB2 = Total memory in row0 + row1 + row2 (in 8 Mbytes) 

63h DRB3 = Total memory in row0 + row1 + row2 + rows (in 8 Mbytes) 

64h DRB4 = Total memory in row0 + row1 + row2 + row3 + row4 (in 8 Mbytes) 

65h DRB5 = Total memory in row0 + row1 + row2 + rows + row4 + row5 (in 8 Mbytes) 

66h DRB6 = Total memory in row0 + row1 + row2 + row3 + row4 + row5 + row6G (in 8 Mbytes) 

67h DRB7 = Total memory in row0 + row1 + row2 + rows + row4 + row5 + row6 + row7 (in 8 Mbytes) 


The DRAM array can be configured with 1 M x 36, 2M x 36, 4 M x 36, 8M x 36 and 16 M x 36 SIMMs. Each 
register defines an address range that causes a particular RAS# line to be asserted (e.g. if the first DRAM 
row is 8 Mbytes in size then accesses within the 0 to 8 Mbytes minus 1 range causes RASO# to be asserted). 
The DRAM Row Boundary (DRB) registers are programmed with an 8-bit upper address limit value. 


oe 


Row Boundary Address. This 8-bit value is compared against address lines HA[30:23] to 
determine the upper address limit of a particular row (i.e., DRB minus previous DRB = row 
size). 


Row Boundary Address 


These 8 bit values represent the upper address limits of the eight rows (i.e., this row - previous row = row 
size). npolluted rows have a value equal to the previous row (row size = 0). DRB7 reflects the maximum 
amount of DRAM in the system. The top of memory is determined by the value written into DRB7. Note that 
the PMC supports a maximum of 1 Gbytes of DRAM. 


As an example of a general purpose configuration where eight physical rows are configured for either single- 
sided or double-sided SIMMs, the memory array would be configured like the one shown in Figure 2. In this 
configuration, the PMC drives two RAS# signals directly to each SIMM row. If single-sided SIMMs are 
populated, the even RAS# signal is used and the odd RAS# is not connected. If double-sided SIMMs are 
used, both RAS# signals are used. 
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Figure 2. SIMMs and Corresponding DRB Registers 


3.2.20. FDHC—FIXED DRAM HOLE CONTROL REGISTER 


Address Offset: 68h 
Default Value: OOh 
Access: Read/Write 


This 8-bit register controls 2 fixed DRAM holes: 512-640 Kbytes and 15-16 Mbytes. | 


Cs 


7:6 | Hole Enable (HEN). This field enables a memory hole in DRAM space. CPU cycles matching an 
enabled hole are passed on to PCI]. PCi cycles matching an enabled hole are ignored by the PMC 
(no DEVSEL#). Note that a selected hole is not remapped. 


Bits[7:6] Hole Enabled 


None 

512 KB-640 KB (128 Kbytes) 
15 MB-16 MB (1 Mbytes) 
Reserved 


5:0 
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3.2.21. § MTT—MULTI-TRANSACTION TIMER REGISTER 


Address Offset: 70h 
Default Value: OOh 
Access: Read/Write 


MTT is an 8-bit register that controls the amount of time that the PMC’s arbiter allows a PCI initiator to 
perform multiple back-to-back transactions on the PCI bus within a guaranteed time slice (measured in terms 
of PCI clocks). The default value of MTT is 0 and disables this function. 


NOTE 
No assumptions should be made about the existence of this register in the future versions of the PMC. 


ee SSCs 


7:3 | Multi-Transaction Timer Count Value (MTTC): The MTT value can be programmed with 8 clock 
granularity in the same manner as the MLT. For example, if the MTT is programmed to 20h, the 
selected value corresponds to the time period of 32 PCI clocks. 


3.2.22. CLT—CPU LATENCY TIMER REGISTER 


Address Offset: 71h 
Default Value: 10h 
Access: Read/Write 


CLT is an 8-bit register that controls the amount of time the CPU is stalled in its snoop phase for a CPU cycle 
destined to PCI, before the cycle is deferred. When the counter value expires, the pending CPU-to-PCI cycle 
is deferred, if there is another transaction pending in the in-order queue. The maximum value of this counter 
is 32 host clocks. 


0 


4:0 | Snoop Stall Count Value. The count value indicates the number of host clocks during which the 


CPU transaction at the top of the in-order queue is stalled in its snoop phase. Once the 16th host 
clock has expired and the current snoop phase has been completed, the cycle will be deferred, if 
another CPU bus cycle is pending. This allows a one wait state medium decode PCI cycle to run (4 
PCI clocks) without being deferred. 
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3.2.23. SMRAM—SYSTEM MANAGEMENT RAM CONTROL REGISTER 


Address Offset: 72h 
Default Value: 02h 
Access: Read/Write 


The SMRAM register controls how accesses to this space are treated. The Open, Close, and Lock SMRAM 
Space bits function only when the SMRAM enable bit is set to a 1. Also, the OPEN bit should be reset before 
the LOCK bit is set. 


a 


: SMM Space Open (DOPEN). When DOPEN=1 and DLCK=0, SMM space DRAM is made visible 


even when CPU cycle does not indicate SMM mode access via EXF4#/Ab7# signal. This is intended 
to help BIOS initialize SMM space. Software should ensure that DOPEN=1 is mutually exclusive with 
DCLS=1. When DLCK is set to a 1, DOPEN is set to 0 and becomes read only. 


SMM Space Closed (DCLS). When DCLS=1, SMM space DRAM is not accessible to data 
references, even if CPU cycle indicates SMM mode access via EXF4#/Ab7# signal. Code references 
may still access SMM space DRAM. This allows SMM software to reference "through" SMM space to 
update the display even when SMM space is mapped over the VGA range. Software should ensure 
that DOPEN=1 is mutually exclusive with DCLS=1. 


4 SMM Space Locked (DLCK). When DLCK=1, DOPEN is set to 0 and both DLCK and DOPEN 
become read only. DLCK can be set to 1 via a normal configuration space write but can only be 
cleared by a power-on reset. The combination of DLCK and DOPEN provide convenience with 
security. The BIOS can use the DOPEN function to initialize SMM space and use DLCK to "lock 


down" SMM space in the future so that no application software (or BIOS itself) can violate the integrity 
of SMM space, even if the program has knowledge of the DOPEN function. 


SMRAM Enable (SMRAME). When SMRAME=1, the SMRAM function is enabled, providing 128 
Kbytes of DRAM accessible at the AOO0Oh address during CPU SMM space accesses (as indicated 
in the second clock of request phase on EXF4#/Ab7# signal). 


SMM Space Base Segment (DBASESEG). This field programs the location of SMM space. SMM 
DRAM is not remapped. It is simply "made visible’, if the conditions are right to access SMM space. 
Otherwise, the access is forwarded to PCI. DBASESEG=010 selects the SMM space as AO000- 
BFFFFh. All other values are reserved. PCI initiators are not allowed access to SMM space. 


PRELIMINARY = 


| 
82441FX (PMC) AND 82442FX (DBX) I ntel ® 


Table 4 summarizes the operation of SMRAM space cycles targeting SMI space addresses: 
Table 4. SMRAM Space Cycles 


CPU SMM Code Fetch Data 
Mode Reference 
Request 
(O=active) 
PCI 


ee ee 


3.2.24. ERRCMD—ERROR COMMAND REGISTER 


Address Offset: 90h 
Default Value: 00h 
Access: Read/Write 


This 8-bit register controls the PMC responses to various system errors. The actual assertion of SERR# or 
PERR# is enabled via the PCI command register. 


SERR# on Receiving Multiple-Bit ECC/Parity (DBX_ERR# asserted) Error Enable. 1=Enable. 
0=Disable. For systems not supporting ECC or parity this bit must be disabled. 


SERR# on Receiving Single-bit ECC Error Enable. When this bit is set to 1, the PMC asserts 
SERR# when it detects a single-bit ECC error reported via the DBX_ERR# signal to the PMC. 
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3.2.25. ERRSTS—ERROR STATUS REGISTER 


Address Offset: 91h 
Default Value: 00h 
Access: Read Only, Read/Write Clear 


This 8-bit register is used to report error conditions received from the DBX via the DBX_ERR# signal. 


feel SSCS anton 


Multi-bit First Error (MBFRE)—RO. This field contains the encoded value of the DRAM row in 
which the first multi-bit error occurred. When an error is detected, this field is updated and the MEF bit 
is set. This field is then locked (no further updates) until the MEF flag is set to 0. If MEF is 0, the value 
in this field is undefined. 


Multiple-bit ECC/Parity (uncorrectable) Error Flag (MEF)—R/WC. If this bit is set to 1, the 
memory data transfer had an uncorrectable error (i.e., multiple-bit error). When enabled, a multiple bit 
error is reported on the DBX_ERR# signal by the DBX and propagated to the SERR# pin of PMC, if 
enabled by bit 1 in the ERRCMD register. BIOS has to write a 1 to clear this bit. 


Note: If the MEF bit is set to a 1, when MEF bit is O and SERR# reporting is enabled, then an error 


will be reported on the SERR# pin. 


Single-bit First Row Error (SBFRE)}—RO. This field contains the encoded value of the DRAM row 
in which the first single-bit error occurred. When an error is detected, this field is updated and SEF is 
set. This field is then locked (no further updates) until the SEF flag is set to 0. If SEF is 0, the value in 
this field is undefined. 


Single-bit (correctable) ECC Error Flag (SELF) —R/WC. If this bit is set to 1, the memory data 
transfer had a single-bit correctable error and the corrected data was sent for the access. When ECC 
is enabled, a single bit error is reported on the DBX_ERR# signal by the DBX and propagated to the 
SERR# pin of the PMC, if enabled by bit 0 in the ERRCMD register. BIOS has to write a 1 to clear 
this bit and unlock the SBFRE field. 
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3.2.26. ©TRC—TURBO RESET CONTROL REGISTER 


Address Offset: 93h 
Default Value: OOh 
Access: Read/Write 


TRC is an 8-bit register that selects turbo/deturbo mode of the CPU, initiates CPU reset cycles, and initiates 
CPU Built-in Self Test (BIST). A 440FX PClset design with PIIX3 should not use this register to initiate a hard 
reset. Instead, an I/O access to OxOCF9h (TRC within the PIIX3) should be used to initiate a hard reset. 


BIST Enable (BISTE). BISTE enables/disables CPU Built-In Self Test. This bit is used in 
conjunction with RCPU and SHRE of this register. When BISTE=1, a subsequent initiation of CPU 
hard reset via the RCPU causes the BIST feature of the CPU to be executed. The PMC only invokes 
the CPU BIST during a hard reset (SHRE=1). In addition to the assertion of the CRESET# for hard 
reset, the PMC asserts INIT#. The DBX then drives CPURST# subsequently to the CPUs. If the CPU 
samples INIT# asserted during the active-to-inactive transition of the CPURST#, the CPU enters the 
BIST mode. 


Reset CPU (RCPU). RCPU is used to initiate a hard or soft reset to the CPU. During hard reset, the 
PMC asserts CRESET# for 2 msec and PCIRST# for 1 msec. During soft reset, the PMC asserts 
INIT#. 


BISTE and SHRE must be set up prior to writing a 1 to this bit. Two operations are required to initiate 


a reset using this register. The first write operation programs BISTE and SHRE to the appropriate 
state while setting RCPU to 0. The second write operation keeps the BISTE and SHRE at their 
programmed state while setting RCPU to 1. When RCPU transitions from a 0 to 1 


- and [BISTE,SHRE] = 0 0, a soft reset is initiated 
- and [BISTE,SHRE] = 0,1, a hard reset is initiated 
= 1,1, CPU BIST mode is enabled 


System Hard Reset Enable (SHRE). This bit is used in conjunction with RCPU bit to initiate either a 
hard or soft reset. When SHRE=1, the PMC initiates a hard reset to the CPU when RCPU bit 
transitions from 0 to 1. When SHRE=0, the PMC initiates a soft reset when RCPU bit transitions from 
0 to 1. 


Deturbo Mode (DM). This bit enables and disables deturbo mode. When DM=1, the PMC is in the 
deturbo mode. In this mode, the PMC disables CPU caching by asserting FLUSH# and stalls the 
CPU pipeline at a rate programmed in the Deturbo Counter Register (DC). When this bit is 0, deturbo 
mode is disabled and Deturbo counter has no effect. 
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4.0. FUNCTIONAL DESCRIPTION 


4.1. System Address Map 


A Pentium Pro system based on the 440FX PClset supports 4 Gbytes of addressable memory space and 64 
Kbytes of addressable I/O space. The lower 1 Mbyte of this addressable memory is divided into regions 
which can be individually controlled with programmable attributes such as disable, read/write, write only, or 
read only (see Register Description section for details on attribute programming). 


NOTE 


The Pentium Pro processor family can have up to 64 Gbytes of addressable memory. The PMC claims 
any access over 4 Gbytes by terminating the transaction (without forwarding it to the PCI bus). Writes 
are terminated by dropping the data and the PMC returns all zeros for reads 


4.1.1. MEMORY ADDRESS RANGES 


Figure 3 represents system memory address map. It shows the main memory regions defined and supported 
by the 440FX PCliset. At the highest level, the address space is divided into four conceptual regions 
(Figure 3). These are the 0O-1-Mbyte DOS Compatibility Area, the 1-Mbyte to 16-Mbyte Extended Memory 
region used by ISA, the 16-Mbyte to 4-Gbyte Extended Memory region, and the 4-Gbyte to 64-Gbyte 
Extended Memory introduced by 36 bit addressing. 


Extended 
Pentium Pro 
Processor 
Memory 


OFFFFFh 


/ 
OFO000h 
OEFFFFh 


Extended 1 GB (TOM va 
Memory (TOM) f 0E0000h 
ODFFFFh 


0C0000h 
: OBFFFFh 
Extended f ieee 
ISA i Compatibility 
Memory fa Memory 


OA0000h 
O9FFFFh | Optional Fixed 
Memory Hole 
Dos 080000h (1 MB) 


Compatibility O7FFFFh 
Memory 
000000h 


Figure 3. Memory Address Map 
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4.1.1.1. Compatibility Area 


The first region of memory is called the Compatibility Area because it was defined for early PCs. This area is 
divided into the following address regions: 


e 0-512-Kbyte DOS Area 

e 512-640-Kbyte DOS Area - Optional ISA/PC!I Memory 

e 640-768-Kbyte Video Buffer Area 

e 768-—896-Kbyte in 16-Kbyte sections (total of 8 sections) - Expansion Area 

e 896—960-Kbyte in 16-Kbyte sections (total of 4 sections) - Extended System BIOS Area 
e 960-Kbyte—1-Mbyte Memory (BIOS Area) - System BIOS Area | 


There are thirteen ranges which can be enabled or disabled independently for both read and write cycles and 
one (512 Kbyte—640 Kbyte) which can be mapped to either main DRAM or PCI. 


DOS Area (00000-9FFFh) 


The DOS area is 640 Kbytes in size and it is further divided into two parts. The 512-Kbyte area at 0 to 
7FFFFh is always mapped to the main memory controlled by the PMC, while the 128-Kbyte address range 
from 080000 to O9FFFFh can be mapped to PCI or to main DRAM. By default this range is mapped to main 
memory and can be declared as a main memory hole (accesses forwarded to PCI) via the FDHC register. 


Video Buffer Area (A0Q000—BFFFFh) 


The 128-Kbyte graphics adapter memory region is normally mapped to a video device on the PCI bus 
(typically VGA controller). This area is not controlled by attribute bits and CPU-initiated cycles in this region 
are always forwarded to PCI for termination. This region is also the default region for SMM space. 


ISA Expansion Area (CO000—DFFFFh) 


This 128-Kbyte ISA Expansion region is divided into eight 16-Kbyte segments. Each segment can be 
assigned one of four Read/Write states: read-only, write-only, read/write, or disabled. Typically, these blocks 
are mapped through the PCI bridge to ISA space. Memory that is disabled is not remapped. 


Extended System BIOS Area (EQO00—-EFFFFh) 

This 64-Kbyte area is divided into four 16-Kbyte segments. Each segment can be assigned independent read 
and write attributes so it can be mapped either to main DRAM or to PCI. Typically , this area is used for RAM 
or ROM. Memory that is disabled is not remapped. 

System BIOS Area (FOO000—-FFFFFh) 

This area is a single 64-Kbyte segment that can be assigned read and write attributes. It is by default (after 


reset) read/write disabled and cycles are forwarded to PCI. By manipulating the read/write attributes, the 
PMC can “shadow” BIOS into main memory. Memory that is disabled is not remapped. 
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4.1.1.2. Extended Memory Area 


This memory area covers 10_0000h (1 Mbyte) to FFFF_FFFFh (4 Gbytes minus 1) address range and it is 
divided into the following regions: 


e DRAM memory from 1 Mbyte to a Top Of Memory (TOM) (maximum of 256 Mbytes using 16Mb DRAM 
technology or 1 Gbyte using 64Mb technology) 


e PCI Memory space from the Top of Memory to 4 Gbytes with two specific ranges 
e APIC Configuration Space from FECO0000h (4 Gbytes minus 20 Mbyte) to FECO_FFFFh 
e High BIOS area from 4 Gbytes to 4 Gbytes minus 2 Mbytes 


Main DRAM Address Range (0010_0000h to Top of Main Memory) 


The address range from 1 Mbyte to the top of main memory is mapped to the main memory address range 
controlled by the PMC. All accesses to addresses within this range are forwarded by the PMC to the main 
memory, unless a hole in this range is created by programming the FDHC register. 


PCI Memory Address Range (Top of Main Memory to 4 Gbytes) 


The address range from the top of main DRAM to 4 Gbytes (top of physical memory space supported by the 
440FX PClset) is normally mapped to PCI. The PMC forwards all accesses within this address range to PCI. 
There are two sub-ranges within this address range defined as APIC Configuration Space and High BIOS 
Address Range. 


1. APIC Configuration Space (FECO_O00Oh-FECO_FFFFh) 
This range is reserved for APIC configuration space which includes the default 1/O APIC configuration 
space. The default Local APIC configuration space is FEEQ_0000h to FEEO_OFFFh. 


The Pentium Pro processor accesses to the Local APIC configuration space do not result in external bus 
activity since the Local APIC configuration space is internal to the processor. However, a MTRR must be 
programmed to make the Local APIC range uncacheable (UC). The Local APIC base address in each 
CPU should be relocated to the FECO_0000h (4 Gbytes minus 20 Mbytes) to FECO_FFFFh range so that 
one MTRR can be programmed to 64 Kbytes for the Local and I/O APICs. The I/O APIC(s) usually reside 
in the I/O Bridge portion of the chip-set or as a stand-alone component(s). 


I/O APIC units are located beginning at the default address FECO_O0OOh. The first I/O APIC is located at 
FECO_0000h. Each I/O APIC unit is located at FECO_x000h where x is I/O APIC unit number 0 through 
F(hex). This address range is normally mapped to PCI (like all other memory ranges above the Top of 
Main Memory). 


The address range between the APIC configuration space and the High BIOS (FECO_FFFFh to 
FFEQO_O000h) is always mapped to the PCI. 
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2. High BIOS Area (FFEO_0000h-FFFF_FFFFh) 
The top 2 Mbytes of the Extended Memory Region is reserved for System BIOS (High BIOS), extended 
BIOS for PCI devices, and the A20 alias of the system BIOS. The CPU begins execution from the High 
BIOS after reset. This region is mapped to the PCI so that the upper subset of this region is aliased to 
16 Mbytes minus 256-Kbyte range. The actual address space required for the BIOS is less than 2 
Mbytes. However, the minimum CPU MTRR range for this region is 2 Mbytes. Thus, the full 2 Mbytes 
must be considered. 


4.1.2. SYSTEM MANAGEMENT MODE (SMM) MEMORY RANGE 


The PMC supports the use of main memory as SMM memory when the System Management Mode is 
enabled. When this function is disabled the memory address range AOOOO—BFFFFh is normally defined as a 
sub-range of the Video Buffer range where accesses are directed to PCI and physical DRAM memory is not 
accessed. When SMM is enabled via SMRAM register, the AOOOO-BFFFFh range is used as a SMM RAM. 
The CPU bus cycles executed in SMM mode access the AOOOO-BFFFFh range by being mapped to the 
corresponding physical DRAM address range instead of being forwarded to PCI. Before this space is 
accessed in SMM mode, the corresponding DRAM range must be first initialized via the SMRAM register. A 
PCI initiator can not access the SMM space. 


NOTE 


A SMM handler accessing the configuration space must save the context of OCF8h when entering the 
SMM space and restore it before leaving SMM space. This is due to the fact that a configuration 
access can be interrupted by a SMI after OCF8h access and before the subsequent OCFCh access. 
For other interrupts, this is handled by disabling the interrupts before a configuration access and 
enabling them after the access is completed. However, this approach does not work for SMI since SMI 
will be recognized even if the interrupts are masked at the CPU level. 


4.1.3. MEMORY SHADOWING 


Any block of memory that can be designated as read only or write only can be “shadowed” into PMC DRAM 
memory. Typically, this is done to allow ROM code to execute more rapidly out of main DRAM. ROM is 
used as_ read only during the copy process while DRAM at the same time is designated write only. After 
copying, the DRAM is designated read only so that ROM is shadowed. CPU bus transactions are routed 
accordingly. The PMC does not respond to transactions originating from PCI or ISA masters and targeted at 
shadowed memory blocks. 


4.1.4. I/O ADDRESS SPACE 


The PMC does not support the existence of any other I/O devices besides itself on the CPU bus. The PMC 
generates PCI bus cycles for all CPU I/O accesses, except to PMC’s internal registers. PMC contains two 
registers in the CPU I/O space, Configuration Address Register (CONFADD) and the Configuration Data 
Register (CONFDATA). These locations are used to implement PCI configuration space access mechanism. 
See the Register Description section for details. 


4.2. Host Interface 
The Host Interface of the 440FX PCISET is designed to support the Pentium Pro family of processors. The 


host interface of the PMC supports up to 66 MHz bus speeds. The PMC also supports a two processor SMP 
mode of operation. 
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4.3. DRAM Interface 


The PMC provides the control signals and address lines to support from 8 Mbytes to 1Gbytes of main 
memory. The data path is through the DBX under the PMC’s control. This section describes the structure 
and implementation of the main memory structure. 


4.3.1. DRAM POPULATION RULES 
The following set of rules allows for optimum configurations. 


° SIMM sockets must be populated in pairs; the memory array is 64- or 72-bits wide 


e SIMM sockets can be populated in any order (i.e., SIMM 0/1 does not have to be populated before 
SIMM sockets 2/3 or 4/5 or 6/7 are used) 


° SIMM socket pairs need to be populated with the same densities (single or double). For example, SIMM 
sockets 2/3 must be populated with identical densities. However, SIMM sockets 4/5 can be populated 
with different densities than SIMM socket pairs 2/3 or 0/1. Additionally, asymmetrical DRAMs of the 
same type should be used in the whole row. 


e BEDO, EDO, and standard page mode can be mixed within the memory array. However, only one type 
should be used per SIMM socket pair. For example, SIMM sockets 2/3 can be populated with EDO while 
SIMM socket 0/1 can be populated with standard page mode. If different type of memory is used for 
different rows, each row will be optimized for that type of memory. 


e |The DRAM Timing register, which provides the DRAM speed grade control for the entire memory array, 
must be programmed to use the timings of the slowest DRAMs installed. 


Table 5 lists a sample of the possible SIMM socket configurations. The following configuration assumes a 
memory array of six double-sided SIMMs. SIMM sockets 0/1, 2/3, and 4/5 each have 2 RAS lines connected 
allowing double-sided SIMMs to be used in these socket pairs. 
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Table 5. Sample Of Possible Mix And Match Options For 6 Row SIMM Configurations 


SIMMO/ SIMM2/ simm4 |D|bdD{oD{|od]oD{oD! D | D | TotalMem. 
R/R{| RI] RI RI RI RI RI. 
B;/B;} B/B/|B!]B{BIB 
o11}/2/3]4/5]6]7 


SIMM1 SIMM3 SIMM5 

(RAST 0,1]#) | (RAST 2,3]#) | (RAS[4,5]#) 

2 [0 wera Joon] conf om [oo [omnfomfomfom] ome 
Twesas [0 [0 _[omfoin] om fom] om] om] om] om] awe 
Tawexsas | 0 | 0 Joanfoon] oa oan oan| oan] cen can] 16 mo 
smases [naa [0 [orf oin] con [oon] con] oan| oan oan] 16 me 
Tawnses | 0 [aon oon] om [orn] cen] omn| oan [oan] seo 


[| «vans [on] oon] oo | om [ocn| oon] oon] oon] a5 mo 
Tsemoes | maa | o [son] 1on] am [200] zon] zon | 2 [zon] 256 ma 
cd 


Note: "S" denotes single-sided SIMM's; "D" denotes double-sided SIMM's. 
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4.3.2. AUTO-DETECTION 


BEDO and EDO DRAM can use the same standard 72-pin SIMM as the module built using FPM DRAM. This 
allows the end user to mix different types of DRAM in the system by providing common 72-pin SIMM sockets. 
The PMC has a special timing mode that may be used by the BIOS to detect the type of DRAM installed on a 
bank-by-bank basis. For EDO detection, the EDO detect bit must be set in the DRAM Control register. These 
algorithms must be implemented by the BIOS during the POST routines. 


Ensure that the DRAMC, DRT 
and DRAMT registers are set 
in default mode of operation 


Write DW Pattem_A 
to DRAM at location n 
Use DRAM address ; : 
location, n= 0 Write zeros to the first DW of the 


subsequent cacheline (Location n 
+ Cacheline) 

Set DRR to 000 to disable 
Refresh. Set WCBRE bit to 1 in 
the DRAMT register and do a QW 

Write of 00h to address 
n+ 21000h (this invokes burst 
ordering in BEDO), Set WCBRE 
bit to 0, Set DAR to 111 to enable YES 


Data Match : 
fast refresh then set DRR to 001 FPM DW Pattern_A Set EDO Detect Bit 
for normal refresh Read 


Read DW Pattem_A at location n 


using address n NO 
am : Pattem_A not Read 
Set Row DRT for BEDO NO 
Size Row per new algorithm, and Read DW Pattem Data Match Pattern_A 
New address, n = (x + row size), EDO not read 
Program DRB 
Read DW Pattem_A at location n 
Set up DRT for FPM and 
DRAMT for fast FPM 


YES mode 
DW Pattem_A read 


Read the DW Pattem_A at location n 


Detect Row Type 


Data Match 


not Read 
Set up DRT for EDO and 


Yes 
Memory Detected and Ec DRAMT for fast EDO Mode 
ized mpty Row, 
ae Set DRT to 


empty 
DW Pattem_A read 


Set up DRT for BEDO and 
DRAMT for fast BEDO 
Mode 


BEDODTEK 


Figure 4. DRAM Auto-Detection Algorithm 


PRELIMINARY = 


a 
82441FX (PMC) AND 82442FX (DBX) d ntel ® 


Detection of BEDO type can be entirely accomplished in software. The memory row can be tested for DRAM 
type using the sequence outlined in the flow chart in Figure 4. The memory sizing and detection scheme 
used in 440FX PClset detects and sizes one row at a time until all rows have been detected and sized. 
Starting with base address 000h, the steps followed are: 


Part of the BEDO DRAM requirement is the burst mode that the DRAM will burst the data out once the 
access has been initiated. The BEDO specification uses a WCBR program cycle to allow for the burst 
sequence to be set to linear or x86 mode. Once set, this mode remains active until another WCBR cycle is 
introduced or power to DRAMs is interrupted. Run a WCBR cycle using the base address + 21000h (this 
enables the BEDO programming mode) to enable the current row into x86 burst mode. Exit the 
programming mode by running a fast refresh cycle using the DRR register. If the current row is BEDO, 
then it allows the DRAM to be set for x86 burst order. 


Use the detection algorithm outlined in Figure 4 to detect the type of DRAM. 


e Use the memory sizing algorithm to detect the memory size. Ensure that the considerations as suggested 
in Section 4.3.4 are used in the implementation of the memory sizing algorithm. Program the DRB register 
appropriately. Add this memory size to the current base address to get the new base address. Repeat the 
process until all of memory is detected and sized. 


After all the rows have been set to the x86 mode, the DRAM array has been primed to enter the detection 
and sizing mode. The BEDO DRAM architecture requires that detection and sizing be done on a per row 
basis as shown in the algorithm above. The actual detection scheme is shown in Fig.5.1. Once the type of 
DRAM has been detected, this information must then be programmed into the DRAM Row Type Register 
for optimal performance. The PMC uses the DRAM Row Type information in conjunction with the DRAM 
timings set in the DRAM Timing Register to configure DRAM accesses optimally. 


4.3.3. DRAM ADDRESS TRANSLATION AND DECODING 


The PMC contains address decoders that translate the address received on the host bus to an effective 
memory or PCI address. This translation takes into account memory gaps and the normal host to memory or 
PCI address. 


The PMC supports a maximum of 64 Mbit DRAM device. The PMC supports the DRAM page size of the 
smallest density DRAM that can be installed in the system. For 36-bit SIMM using 1M x 4 DRAMs, the 
overall DRAM SIMM page size is 4096 bytes (4 KB). Since each row supports 2 SIMMs for a 64-bit wide 
memory, the effective page size supported by the PMC is 8 Kbytes. The page offset address is driven over 
MA[8:0} when driving the column address. MA[11:0] are translated from the address lines HA[26:3] for all 
memory accesses. The multiplexed row/column address to the DRAM memory array is provided by 
MA[11:0]. MA[11:0] are derived from the host address bus as defined by Table 6 for symmetrical and 
asymmetrical DRAM devices. The DRAM addressing and the size supported by these options is shown in 
Table 7. 


Table 6. DRAM Address Translation 


Memory Addr., 
MA[11:0] 


|Row Address }A24 | A23 | At /A20 | A19 A183 | |A17 | Ate | AIS A14 |A13 | AZ 


1 For supporting 12 x 11 and 12 x 12 addressing this bit is driven as A25. This accomplished dynamically by the PMC. 
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Table 7. Memory Mapping Options 


Memory Org. Addressing Address Size 


4.3.4. PSEUDO-ALGORITHM FOR DYNAMIC MEMORY SIZING 


PMC implements asymmetrical addressing as described in Section 5.3 including support for 12 x 10 DRAM 
addressing. This section describes a pseudo-algorithm for calculating the memory sizing dynamically, 
including identification of memory addressing type. This pseudo-algorithm should be appropriately added to 
the algorithm used currently in the BIOS or the OS. A generic algorithm is described as follows: 


Configure row size for 128 MBytes (12 x 12 addressing) with base address = Baddr 
Write a pattern OCh to location Baddr + 0000_0000h (encoding for 8 MB) 

Write a pattern 04h to location Baddr + 0400_0000h (encoding for 16 MB) 

Write a pattern 03h to location Baddr + 0200_0000h (encoding for 32 MB) 

Write a pattern O1h to location Baddr + 0100_0000h (encoding for 64 MB) 

Write a pattern 00h to location Baddr + 0080_0000h (encoding for 128 MB) 

Read from locations Baddr + 0200_0000h into Register X 

OR the value in register X with data from location Baddr + 0000_0000h into register X 
Increment register X 


0) Oe OS, Se Oe 


The result of this register X contains the correct value to add to the previous DRB register to get the correct 
value for the current DRB register. It is important to note that all the DRBs must be programmed to 128 MB 
until all the rows have been sized. The correct value of the row sizes should be programmed in all the DRBs 
after all the rows have been sized. 7 
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Table 8. Algorithm Results 


4.3.5. DATA INTEGRITY SUPPORT 


ECC or parity can be checked on the DRAM interface. As a default no parity is selected. The DRAM must 
be populated with 72-bit wide memory to implement ECC or parity. 


4.3.5.1. Software Requirements 


BIOS must be aware of the implication of the optional parity support. All physically present DRAM must be 
first written before SERR#-based NMI generation in the PIIX3 is enabled. 


Detection of 64- versus 72-bit Wide SIMMS. The PMC only supports parity or ECC properly if all DRAMs 
are 72-bit wide. A system with a mixture of 64- and 72-bit wide memory should disable parity and ECC. BIOS 
can detect the 64-bit wide DRAMs (so that it can disable SERR# on parity error) by writing data that forces 
the parity bits to be all 1s for address A, and then writing data that forces the parity bits to be all 0’s in another 
location (address B). Now, if address A is read, no parity error will result only if there’s a 72-bit wide DRAM 
present, whereas parity errors would get flagged in the ERRSTS register for a 64-bit wide DRAM. 


4.3.5.2. Parity Detection 


When parity is enabled, the DRAM parity protection is 8-bit based even parity. If the DRAM array is populated 
with 64-bit memory (vs 72-bit) the parity logic, such parity errors are registered in bit 4 in the ERRSTS 
register. For such DRAM configurations, bit 1 of the ERRCMD register must be 0 (default) to prevent these 
errors from being signaled via the SERR# mechanism. 


Byte 7 Byte 0 Parity Bits 


wou [efete fala) — worrn PPP Pp Ppl 


Byte 7s Byte 0 
ees d Check Sum [1 |» MEF=1 


Figure 5. Parity Detection 
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4.3.5.3. Error Detection and correction 

ECC is an optional data integrity feature provided by the PMC. The feature provides single-error correction, 
double-error detection, and detection of all errors confined to a single nibble (SEC-DED-S4ED) for the DRAM 
memory subsystem. Additional features are provided that enable software-based system management 
capabilities. 


ECC Generation. When enabled, the PMC generates an 8-bit protection code for 64-bit data during DRAM 
write operations. If the original write is less than 64-bits, a read-merge-write operation is performed. 


ECC Checking and Correction. When enabled, the PMC detects all single and dual-bit errors, and corrects 
all single-bit errors during DRAM reads. The corrected data is transferred to the requester (CPU or PCl). 
Note that the corrected data is not written back to DRAM. 


Byte 7 Byte 0 Syndrome Bits 


Error detected and correct data passed to the host. 


Figure 6. Single Bit Error Detection and Correction (SEC) 


Byte 7 Byte 0 Syndrome Bits 


Error detected and correct data passed to the host. 


Figure 7. Multiple Bit Error Detection (DED) 


Error Reporting. When ECC is enabled and ERRCMD is used to set SERR# functionality, ECC errors are 
signaled to the system via the SERR# pin. The PMC can be programmed to signal SERR# on uncorrectable 
errors, correctable errors, or both. The type of error condition is latched until cleared by software (regardless 
of SERR# signaling). 
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ERRCMD(0] 


ERRCMD(1] 


Figure 8. SERR# Generation for Single- or Double-bit Error 


When a single or multi-bit error is detected, the offending DRAM row ID is latched in the ERRSTS register in 
the PMC. The latched value is held until software explicitly clears the error status flag. 


Software Requirements 


Initialization. If the ECC feature or parity is enabled, BIOS must take care to properly initialize the memory 
before enabling the checking. Software should first ensure PCICMD[SERRE] =0, then enable ECC or parity 
via ERRCMD. Next, the entire DRAM array should be written to ensure valid syndrome/parity bits. Finally, the 
desired ECC/parity error reporting should be enabled via the ERRCMD and PCICMD registers. 


Parity Error Handling. Parity error handling should be via the system's normal NMI routines. 


ECC Support Levels. The PMC allows for various levels of ECC support, depending on the specific platform 
requirements. The software architecture requirements vary based on the level of support implemented. The 
levels and basic software implications are summarized in the table below. 


Table 9. ECC Software Levels 


- Error Checking/Correction - Configuration BIOS 

- Error Checking/Correction. - Configuration BIOS. 

- Error Scrubbing - SMI Scrubbing Routine 
- Error Checking/Correction. - Configuration BIOS. 


- Error Scrubbing. - SMI Scrubbing Routine. 


- System Management (e.g. error oe error | - OS-dependent System management 
isolation, memory remapping, handler/applet 


Level 1 


Level 1 defines a minimal support level for ECC handling that would use the system’s standard NMI 
routine. The configuration BIOS enables SERR# generation only for uncorrectable errors, and disables 
SERR# generation for correctable errors. The NMI routine will interpret the uncorrectable error event as a 
parity error, and typically reboot the system. | 
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DBX_ERR# 


Figure 9. Level 1 SERR# Generation for ECC and Parity 


Level 2 


Level 2 adds support for error scrubbing of correctable errors using operating system independent 
mechanisms. SMI is the preferred mechanism to implement OS independence. In this case, the SMI 
handler would be invoked for both correctable and uncorrectable errors. The DBX_ERR# signal from the 
DBX is connected to the PMC as well as the EXT_SMI# input of the PIIX3. Any error signalled via the 
DBX_ERR# will trigger a SMI and consequently the SMI handler will be invoked. Note that both 
ERRCMD[1:0] bits should be disabled to prevent the generation of SERR# upon receipt of the 
DBX_ERR#. 


For correctable errors, the handler first clears the error flags and then starts a scrub process. The time 
spent in an SMI routine should be minimized, since interrupts are disabled and OS services (e.g. real 
time clocks) could be adversely affected. To minimize time spent during the SMI handler, the scrub 
process should be distributed into small time slices. The handler can setup future SMI events to re-occur 
based on a hardware timer (e.g. the “Fast Off’ green timer in Intel PClset standard expansion bridges 
[PIIX3]) until the memory scrub has completed. 


The following example estimates the worst-case scrub duration for a single correctable error. 


Example Assumptions: 

e 128 Mbytes/Row (64Mbit technology) =4M lines at 32 bytes/line 

e Scrub operation memory bound by linefill + writeback (with medium DRAM timings) = 30 clks/line 
e SMI scrub time slice budget = 1 msec/SMI 

e Fast-off SMI interrupt interval = 100 msec/interrupt 


With the above assumptions The scrub time is: 

e the time to scrub one row is 4M lines/row X 30 clks/line X 15ns/clk = 1.8 sec/row. 

e Thus, spreading the scrub time requires: (1.8 sec/row)/(1msec /SMI) = 1800 SMI events. 

e The total duration for the scrub SMI events will be 1800 SMI events * 100msec/interrupt = 180 sec. 


PRELIMINARY ee 


82441FX (PMC) AND 82442FX (DBX) / ntel ® 


For uncorrectable errors, the SMI handler should first log the error and then pass the error to the system’s 
normal NMI handler, making it appear as a standard parity error to the software. To pass the NMI event, 
the SMI handler will: 


e Log the MBFRE field and clear the MEF bit 

e Set ERRCMD[1] to enable SERR# assertion 

e Write a 1 to MEF bit to cause SERR# assertion 

e Clear ERRCMD[1] bit to 0 to allow logging of subsequent errors 


This will result in a NMI which will be handled after exiting the SMI handler. 


DBX_ERR# 


Figure 10. Level 2 SERR# Generation for ECC and Parity 


Level 3 


Level 3 adds more sophisticated system management functions beyond simple error scrubbing. Typical 
functions could include error event logging, error isolation, memory remapping, system diagnostics and user 
interface applications. Software to implement Level 3 functions are OS dependent, and beyond the scope of 
this document. However, the features used to implement Level 2 functions can also be leveraged in Level 3 
systems. 


4.3.5.4. ECC/Parity Test Mode 


PMC and DBX provide a software mechanism to test the parity and ECC checking logic. After CRESET# the 
DBX ECC/Parity control logic is set in the default mode of operation. To enter the ECC/Parity Test Mode 
PMCCFG[EPTE] must be set to 1. This causes the PMC to send a command to the DBX to configure the 
latter's ECC/Parity logic for test mode. In the test mode, the DBX signals MDP[7:0] are forced to “0” during 
writes to DRAM. During reads, MPD[7:0] are compared against internally generated ECC/Parity Checksum. 
Errors generated due to miscompares are reported normally via the DBX_ERR# signal. This mechanism can 
be used to test both single-bit and mulitple-bit ECC and parity errors. In case of single-bit errors, a zero 
pattern can be written to memory followed by a walking “1” pattern. This should result in the corrected data 
being returned to the CPU, (i.e., all Os). The SEF bit can also be polled to test for single-bit error logging. In 
case of multiple bit and parity errors, writing different patterns and reading them back should result in a mulit- 
bit or parity error which would be logged in the MEF bit. 
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4.4. PCI Bus Arbitration 


The PMC's PCI Bus arbiter allows concurrent host and PCI transactions to main memory. The arbiter 
supports five PCI masters in addition to the PIIX3 component (Figure 11). REQ([4:0]#/GNT[4:0]# are used by 
PCI masters. PHLD#/PHLDA# are the arbitration request/grant signals for the PIIX3 and provide guaranteed 
access time capability for ISA masters. The arbiter dynamically allocates to PIIX3 to optimize system 
latencies for better Universal Serial Bus (USB) performance. 


Multi-Transaction Timer (MTT) 


The arbitration mechanism is enhanced with a Multi-Transaction Timer mechanism. The effect of the MTT is 
to guarantee a minimum time slice on PCI to an agent that keeps its request asserted. (Note that this 
mechanism differs from the MLT operation, that enforces a maximum time slice for an agent.) The MTT 
algorithm ensures a fairer bandwidth allocation for PCI devices that generate short burst traffic, or for multi- 
function devices with several bus master agents behind one physical PCI interface. This feature improves the 
PCI bandwidth allocation to short bursts, an important consideration for example, with typical video capture 
devices. 


Passive Release and Bus Lock 


To comply with PCI Specfication, revision 2.1 latency requirements, the PMC supports passive release. The 
PMC disables CPU-to-PCI posting during the passive release, except for transactions to the USWC region. 
The PMC only supports bus lock mode. The bus lock mode precludes 3rd party locks. 


PHLDA# 
GNT0# 
GNT1# 


GNT2# 
GNT3# 
GNT4# 


ARBITER 


Figure 11. PCI Bus Arbiter 
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Devices 


Figure 12. System Arbiter 


4.5. System Clocking and Reset 


4.5.1. HOST FREQUENCY SUPPORT 


The Pentium Pro processor uses a clock ratio scheme where the host bus clock frequency is multiplied by a 
ratio to produce the processor's core frequency. The PMC supports a host bus frequency ranging up to 66 
MHz. The external synthesizer is responsible for generating the host clock. The Pentium Pro processor 
samples four signals LINT[1:0], IGNNE# and A20M# on the active-to-inactive edge of CPURST# to set the 
ratio. 


4.5.2. CLOCK GENERATION AND DISTRIBUTION 


The PMC receives two outputs of a clock synthesizer on the HCLKIN and PCLKIN pins. The DBX also 
receives a clock on its HCLKIN pin. The PMC uses the HCLKIN signal to drive the host, memory and private 
bus and the PCLKIN bus to drive the PCI interface. 


The clock signal requirements for the CPU clock are outlined in the Pentium Pro Bus Input Clock 
Specification. The clock skew between two host clock outputs of the synthesizer must be less than 250 ps (at 
1.5V). The clock skew between two PCI clock outputs of the synthesizer must be less than 500 ps (at 1.5V). 
In addition, the host clocks should always lead the PCI clocks by a minimum of 1 ns and a maximum of 6 ns. 
The PMC requires a 45%/55% maximum output duty cycle. A maximum of 200 ps jitter must be maintained 
on the host clocks going from cycle to cycle. 


4.5.3. SYSTEM RESET 


The PMC contains reset logic for both soft and hard reset. The PMC generates a hard reset at power on. The 
PMC can be programmed to generate a hard or a soft reset after power on. The PMC generates a soft reset 
in response to a shutdown bus cycle on the CPU bus. External logic is required to combine the PMC soft 
reset with the keyboard controller and I/O port 92 soft reset generation. The PMC can also be used to invoke 
BIST on the CPU. Figure 13 shows the reset structure for the 440FX PClset. 
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CPURST# 
PWROK 
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Panel IGNEE#, INTR, CPURST# 
Reset 


Switch IOAPIC 
. RESET# 


ISA Bus 


440FXRES 


Figure 13. Reset Structure for 440FX PClset with PIIX3 


4.5.3.1. Hard Reset 


There are two sources of hard reset in the system: 
e During Power-up, PWROK asserted 1 ms after the system power has stabilized 
e I/O write to the PMC Turbo/Reset Control Register (configuration offset 93h) 
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Figure 14. Hard Reset 


The PMC generates a hard reset for the system when the PWROK signal is sampled inactive (low). The PMC 
generates PCIRST# and CRESET# while the PWROK input is sampled inactive (low). The PMC continues to 
assert PCIRST# for 1 msec and CRESET# for 2 msec after sampling PWROK asserted. CRESET# is an 
input to the DBX. The DBX drives CPURST# to the CPUs as long as the CRESET# input is sampled active. 
The DBX releases CPURST# (external GTL+ pullup will drive it high) 2 host clocks after CRESET# is 
sampled high by the DBX. PCIRST# is negated 1 msec after PWROK is asserted and CRESET# is negated 
2 msec after PWROK is negated. CPURST# and CRESET# are released synchronously to the HCLKIN input. 
PCIRST# is driven synchronously to the PCLKIN input. 


Note that the CPURST# output signal from the PIIX3 should be connected to the PMC’s PWROK input signal 
through an inverter. This insures that PIIX3 is reset before the first PCl cycle occurs on the PCI bus. 
Otherwise, the PWROK signal should be connected to a schmitt trigger buffered version of the power supply 
POWER_GOOD signal. 


The PMC is the only agent in the system that is allowed to drive PCIRST#. Note that the PCIRST# signal 
from the PIIX3 should be left as a no connect. 


The PMC can be programmed to generate a hard reset through the Turbo/Reset Control Register 
(configuration offset 93h). The PMC asserts CRESET# for a minimum of 2 msec and PCIRST# for 1 msec. 
The DBX correspondingly generates the CPURST# to the CPUs. Note that the internal registers of the PMC 
are also reset. 


NOTE 


The PMC should not be used to generate a hard reset in a system designed with PIIX3. Instead use 
the PIIX3 to generate the hard reset. 


The PMC straps are sampled on the rising edge of PWROK. The DBX receive CRESET# as an input, and 
reset the internal DBX state machines. The DBX straps are sampled on the rising edge of CRESET#. 
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4.5.3.2. Soft Reset 


There are 4 sources of soft reset in the system: 

e CPU shutdown bus cycle 

e I/O write to the keyboard controller 

e |/O write to port 92h 

e I/O write to the PMC Turbo/Reset Control Register 


When the PMC detects a CPU shutdown bus cycle, it terminates the CPU bus cycle with no data response 
type as defined in the Pentium Pro processor EBS and then asserts INIT# for a minimum of 4 host clocks. 
The PMC can be programmed to generate a soft reset through the Turbo/Reset Control Register (offset 93h). 
The PMC asserts INIT# for a minimum of 4 host clocks. The INIT# output of the PMC must be externally 
gated with the !I/O port 92 (not supported on PIIX3) and keyboard controller soft reset sources as shown in 
Figure 15. 


KBC_RESET# 
I/O Port92_RESET# 


CPU_INIT# 
PMC_INT# 


Figure 15. Reset Sequencing 


4.5.3.3. CPU BIST 


The PMC can be programmed to activate BIST mode of the CPU through the Turbo Reset Control register 
(offset 93h). The PMC asserts both CRESET# and INIT#. The PMC asserts PCIRST# for 1 msec, CRESET# 
for 2 msec and asserts INIT# for 2 msec plus 16 host clocks. The DBX correspondingly asserts CPURST# to 
the CPUs. This invokes BIST mode on the CPU. 
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Figure 16. PMC Pinout Diagram 
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Table 10. PMC Alphabetical 
Pin Assignment 
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Table 10. PMC Alphabetical 
Pin Assignment 
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Table 10. PMC Alphabetical Table 10. PMC Alphabetical Table 10. PMC Alphabetical 
Pin Assignment Pin Assignment Pin Assignment 
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5.2. DBX Pinout Information 
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Figure 17. DBX Pinout Diagram 


ee PRELIMINARY 


Table 11. DBX Alphabetical 
Pin Assignment 


: 

: 

; 

z 
GND 


1 


Type 


/O 


ND 
ND 
N 
GND 
GND 
GND 
GND | 
GND 
GND 
GND 


G) 


NO 
o>) 


—_ Orn & | @ — | ® 
© > | © =~ 1|1|O; FR 1, oO] NMI Oo o) 


G) 
Oo 
nN 


io) 


G) | G) |} @ G) | @ | @ 
-_/|/Z/i2z =—|/Z2iZz 
O;O0;0 O0U10;,90 
~I a} ol] oa 
Nn ie) 


= 
0 


co 
or 


PRELIMINARY 


82441FX (PMC) AND 82442FX (DBX) 


Table 11. DBX Alphabetical 
Pin Assignment 
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5.3. PMC & DBX Package Specifications 


Both PMC and DBX use a 208 pin PQFP package (Figure 18). 
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Figure 18. 208 Pin Quad Flat Pack (QFP) Dimensions 


Table 12. 208 Pin Quad Flat Pack (QFP) Dimensions 
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6.0. TESTABILITY 


The test modes described below are provided in the 82441FX and 82442FX for Automated Test Equipment 
(ATE) board level testing. 
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Figure 19. Hard Reset 


6.1. | 82441FX (PMC) Test Modes 


The test mode of the 82441FX is latched at the rising edge of PWROK. The PMC uses PD[15:12] as test 
mode inputs. The PMC test modes are selected as shown in Table 13. 


Table 13. PMC Test Mode Select 


Mode Selected 
Normal (Default) 
NAND Tree 


Normal Mode - This is the functional mode of PMC. It is enabled as default via weak 50 KQ pulldown 
devices. 


NAND Tree Mode - This allows ATE to test the connectivity of the PMC signal pins. PD[9:8] are outputs of 
the NAND tree, PD9 is the end of the NAND tree and PD8 is the midpoint. The procedure for enabling this 
mode is as follows: 


e Initiate HCLK and PCLK. Set PD[15:12]=0011 which is latched on the low to high edge of PWROK. Stop 
all clocks. 


e Put DBX, PIIX3, and IOAPIC in tristate mode. 
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e All inputs are forced high, starting from PD7 (input furthest from PD9), and following the pinout until it 
ends with PD10. 


e Inputs are pulsed low, one at a time starting with PD7. This toggles PD9 each time an input is changed. 
The last input in the chain is PD10. NAND Tree order follows the pinout. PWROK, CRESET#, PD9 and 
PD8 are not a part of the NAND tree. 


PD[7]- NAND Tree Start Input 


PD[8]-NAND Tree Midpoint Output 


PD[9]-NAND Tree End Output 


PD[10]-NAND Tree End Input 


Figure 20. PMC NAND Tree 


All 1s Mode - This mode allows all the outputs to be set high (set to 1). Setting PD[15:12]=0011 enables this 
mode on the low to high transition of PWROK. 


All Os Mode - This mode allows all the outputs to be set low (set to 0). Setting PD[15:12]=0100 enables this 
mode on the low to high transition of PWROK. 


Tristate Mode - This mode allows all the outputs to be tristated “High-Z”. Setting PD[15:12]=1001 enables 
this mode on the low to high transition of PWROK. All GTL+ inputs are turned off. 


6.2. DBX Test Mode 


The test mode of the 82442FX is latched at the rising edge of CRESET#. The DBX uses PD[5:2] as test 
mode inputs. The DBX test modes are selected as shown in Table 14. 


Table 14. DBX Test Mode Select 


Normal Mode - This is the functional mode of DBX. It is enabled as default via weak 50 KQ pulldown 
devices. 
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NAND Tree Mode - This allows ATE to test the connectivity of the DBX signal pins. PD[9:8] are outputs of 
the NAND tree; PD9 is the end of the NAND tree and PD8 is the midpoint. The procedure for enabling this 
mode is as follows: 


e Initiate HCLK and PCLK. Set PD[5:2]=0011 which is latched on the low to high edge of CRESET#. Stop 
all clocks. 


e Put PMC, PIIX3, and IOAPIC in tristate mode. 


e All inputs are forced high, starting from PD7 (input furthest from PD9), and following the pinout until it 
ends with PD10. 


e Inputs are pulsed low, one at a time starting with PD7. This toggles PD9 each time an input is changed. 
The last input in the chain is PD10. NAND Tree order follows the pinout. CRESET#, PD9, and PD8 are 
not a part of the NAND tree. 


NAN D Tree Start Input - PD[7] 


NAND Tree Midpoint Output - PD [8] 


NAND Tree End Output - PD[9] 


NAND Tree End Input - PD[1 0] 


DBX_NAND 


Figure 21. DBX NAND Tree 


All 1s Mode - This mode allows all the outputs to be set high (set to 1). Setting PD[5:2]=0011 enables this 
mode on the low to high transition: of CRESET#. 


All Os Mode - This mode allows all the outputs to be set low (set to 0). Setting PD[5:2]=0100 enables this 
mode on the low to high transition of CRESET#. 


Tristate Mode - This mode allows all the outputs to be tristated “High-Z”. Setting PD[5:2]=1001 enables this 
mode on the low to high transition of CRESET#. All GTL+ inputs are turned off. 
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